<?xml version='1.0' encoding='UTF-8' standalone='yes'?>
<!DOCTYPE html>
<html lang='en-us' xmlns='http://www.w3.org/1999/xhtml' >
<head>
<title>系统管理模块表结构</title>
<meta http-equiv='Content-Type' content='text/html; charset=UTF-8'/>
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
<link rel="shortcut icon" href="https://www.dbschema.com/images/favicon.ico">
<style>

/*!
 * Bootstrap v4.1.3 (https://getbootstrap.com/)
 * Copyright 2011-2018 The Bootstrap Authors
 * Copyright 2011-2018 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */:root{--blue:#007bff;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#fd7e14;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#6c757d;--gray-dark:#343a40;--primary:#007bff;--secondary:#6c757d;--success:#28a745;--info:#17a2b8;--warning:#ffc107;--danger:#dc3545;--light:#f8f9fa;--dark:#343a40;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-family-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}*,::after,::before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:transparent}@-ms-viewport{width:device-width}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;text-align:left;background-color:#fff}[tabindex="-1"]:focus{outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0}address{margin-bottom:1rem;font-style:normal;line-height:inherit}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects}a:hover{color:#0056b3;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus,a:not([href]):not([tabindex]):hover{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto;-ms-overflow-style:scrollbar}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg{overflow:hidden;vertical-align:middle}table{border-collapse:collapse}caption{padding-top:.75rem;padding-bottom:.75rem;color:#6c757d;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-family:inherit;font-weight:500;line-height:1.2;color:inherit}.h1,h1{font-size:2.5rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{margin-top:1rem;margin-bottom:1rem;border:0;border-top:1px solid rgba(0,0,0,.1)}.small,small{font-size:80%;font-weight:400}.mark,mark{padding:.2em;background-color:#fcf8e3}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:90%;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote-footer{display:block;font-size:80%;color:#6c757d}.blockquote-footer::before{content:"\2014 \00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:.25rem;background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{font-size:90%;color:#6c757d}code{font-size:87.5%;color:#e83e8c;word-break:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:87.5%;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{display:block;font-size:87.5%;color:#212529}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-right:0;padding-left:0}.col,.col-1,.col-10,.col-11,.col-12,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-auto,.col-lg,.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-auto,.col-md,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-auto,.col-sm,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-auto,.col-xl,.col-xl-1,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-auto{position:relative;width:100%;min-height:1px;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-ms-flex-order:-1;order:-1}.order-last{-ms-flex-order:13;order:13}.order-0{-ms-flex-order:0;order:0}.order-1{-ms-flex-order:1;order:1}.order-2{-ms-flex-order:2;order:2}.order-3{-ms-flex-order:3;order:3}.order-4{-ms-flex-order:4;order:4}.order-5{-ms-flex-order:5;order:5}.order-6{-ms-flex-order:6;order:6}.order-7{-ms-flex-order:7;order:7}.order-8{-ms-flex-order:8;order:8}.order-9{-ms-flex-order:9;order:9}.order-10{-ms-flex-order:10;order:10}.order-11{-ms-flex-order:11;order:11}.order-12{-ms-flex-order:12;order:12}.offset-1{margin-left:8.333333%}.offset-2{margin-left:16.666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.333333%}.offset-5{margin-left:41.666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.333333%}.offset-8{margin-left:66.666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.333333%}.offset-11{margin-left:91.666667%}@media (min-width:576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-sm-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-sm-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-sm-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-sm-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-sm-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-sm-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-sm-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-sm-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-sm-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-ms-flex-order:-1;order:-1}.order-sm-last{-ms-flex-order:13;order:13}.order-sm-0{-ms-flex-order:0;order:0}.order-sm-1{-ms-flex-order:1;order:1}.order-sm-2{-ms-flex-order:2;order:2}.order-sm-3{-ms-flex-order:3;order:3}.order-sm-4{-ms-flex-order:4;order:4}.order-sm-5{-ms-flex-order:5;order:5}.order-sm-6{-ms-flex-order:6;order:6}.order-sm-7{-ms-flex-order:7;order:7}.order-sm-8{-ms-flex-order:8;order:8}.order-sm-9{-ms-flex-order:9;order:9}.order-sm-10{-ms-flex-order:10;order:10}.order-sm-11{-ms-flex-order:11;order:11}.order-sm-12{-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.333333%}.offset-sm-2{margin-left:16.666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.333333%}.offset-sm-5{margin-left:41.666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.333333%}.offset-sm-8{margin-left:66.666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.333333%}.offset-sm-11{margin-left:91.666667%}}@media (min-width:768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-md-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-ms-flex-order:-1;order:-1}.order-md-last{-ms-flex-order:13;order:13}.order-md-0{-ms-flex-order:0;order:0}.order-md-1{-ms-flex-order:1;order:1}.order-md-2{-ms-flex-order:2;order:2}.order-md-3{-ms-flex-order:3;order:3}.order-md-4{-ms-flex-order:4;order:4}.order-md-5{-ms-flex-order:5;order:5}.order-md-6{-ms-flex-order:6;order:6}.order-md-7{-ms-flex-order:7;order:7}.order-md-8{-ms-flex-order:8;order:8}.order-md-9{-ms-flex-order:9;order:9}.order-md-10{-ms-flex-order:10;order:10}.order-md-11{-ms-flex-order:11;order:11}.order-md-12{-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.333333%}.offset-md-2{margin-left:16.666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.333333%}.offset-md-5{margin-left:41.666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.333333%}.offset-md-8{margin-left:66.666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.333333%}.offset-md-11{margin-left:91.666667%}}@media (min-width:992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-lg-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-ms-flex-order:-1;order:-1}.order-lg-last{-ms-flex-order:13;order:13}.order-lg-0{-ms-flex-order:0;order:0}.order-lg-1{-ms-flex-order:1;order:1}.order-lg-2{-ms-flex-order:2;order:2}.order-lg-3{-ms-flex-order:3;order:3}.order-lg-4{-ms-flex-order:4;order:4}.order-lg-5{-ms-flex-order:5;order:5}.order-lg-6{-ms-flex-order:6;order:6}.order-lg-7{-ms-flex-order:7;order:7}.order-lg-8{-ms-flex-order:8;order:8}.order-lg-9{-ms-flex-order:9;order:9}.order-lg-10{-ms-flex-order:10;order:10}.order-lg-11{-ms-flex-order:11;order:11}.order-lg-12{-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.333333%}.offset-lg-2{margin-left:16.666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.333333%}.offset-lg-5{margin-left:41.666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.333333%}.offset-lg-8{margin-left:66.666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.333333%}.offset-lg-11{margin-left:91.666667%}}@media (min-width:1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-xl-1{-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-xl-2{-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-xl-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-xl-5{-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-xl-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-xl-8{-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-xl-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-xl-11{-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-xl-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-ms-flex-order:-1;order:-1}.order-xl-last{-ms-flex-order:13;order:13}.order-xl-0{-ms-flex-order:0;order:0}.order-xl-1{-ms-flex-order:1;order:1}.order-xl-2{-ms-flex-order:2;order:2}.order-xl-3{-ms-flex-order:3;order:3}.order-xl-4{-ms-flex-order:4;order:4}.order-xl-5{-ms-flex-order:5;order:5}.order-xl-6{-ms-flex-order:6;order:6}.order-xl-7{-ms-flex-order:7;order:7}.order-xl-8{-ms-flex-order:8;order:8}.order-xl-9{-ms-flex-order:9;order:9}.order-xl-10{-ms-flex-order:10;order:10}.order-xl-11{-ms-flex-order:11;order:11}.order-xl-12{-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.333333%}.offset-xl-2{margin-left:16.666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.333333%}.offset-xl-5{margin-left:41.666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.333333%}.offset-xl-8{margin-left:66.666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.333333%}.offset-xl-11{margin-left:91.666667%}}.table{width:100%;margin-bottom:1rem;background-color:transparent}.table td,.table th{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table tbody+tbody{border-top:2px solid #dee2e6}.table .table{background-color:#fff}.table-sm td,.table-sm th{padding:.3rem}.table-bordered{border:1px solid #dee2e6}.table-bordered td,.table-bordered th{border:1px solid #dee2e6}.table-bordered thead td,.table-bordered thead th{border-bottom-width:2px}.table-borderless tbody+tbody,.table-borderless td,.table-borderless th,.table-borderless thead th{border:0}.table-striped tbody tr:nth-of-type(odd){background-color:rgba(0,0,0,.05)}.table-hover tbody tr:hover{background-color:rgba(0,0,0,.075)}.table-primary,.table-primary>td,.table-primary>th{background-color:#b8daff}.table-hover .table-primary:hover{background-color:#9fcdff}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#9fcdff}.table-secondary,.table-secondary>td,.table-secondary>th{background-color:#d6d8db}.table-hover .table-secondary:hover{background-color:#c8cbcf}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#c8cbcf}.table-success,.table-success>td,.table-success>th{background-color:#c3e6cb}.table-hover .table-success:hover{background-color:#b1dfbb}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b1dfbb}.table-info,.table-info>td,.table-info>th{background-color:#bee5eb}.table-hover .table-info:hover{background-color:#abdde5}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#abdde5}.table-warning,.table-warning>td,.table-warning>th{background-color:#ffeeba}.table-hover .table-warning:hover{background-color:#ffe8a1}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#ffe8a1}.table-danger,.table-danger>td,.table-danger>th{background-color:#f5c6cb}.table-hover .table-danger:hover{background-color:#f1b0b7}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#f1b0b7}.table-light,.table-light>td,.table-light>th{background-color:#fdfdfe}.table-hover .table-light:hover{background-color:#ececf6}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#ececf6}.table-dark,.table-dark>td,.table-dark>th{background-color:#c6c8ca}.table-hover .table-dark:hover{background-color:#b9bbbe}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#b9bbbe}.table-active,.table-active>td,.table-active>th{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:rgba(0,0,0,.075)}.table .thead-dark th{color:#fff;background-color:#212529;border-color:#32383e}.table .thead-light th{color:#495057;background-color:#e9ecef;border-color:#dee2e6}.table-dark{color:#fff;background-color:#212529}.table-dark td,.table-dark th,.table-dark thead th{border-color:#32383e}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,.05)}.table-dark.table-hover tbody tr:hover{background-color:rgba(255,255,255,.075)}@media (max-width:575.98px){.table-responsive-sm{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-sm>.table-bordered{border:0}}@media (max-width:767.98px){.table-responsive-md{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-md>.table-bordered{border:0}}@media (max-width:991.98px){.table-responsive-lg{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-lg>.table-bordered{border:0}}@media (max-width:1199.98px){.table-responsive-xl{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive>.table-bordered{border:0}.form-control{display:block;width:100%;height:calc(2.25rem + 2px);padding:.375rem .75rem;font-size:1rem;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media screen and (prefers-reduced-motion:reduce){.form-control{transition:none}}.form-control::-ms-expand{background-color:transparent;border:0}.form-control:focus{color:#495057;background-color:#fff;border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.form-control::-webkit-input-placeholder{color:#6c757d;opacity:1}.form-control::-moz-placeholder{color:#6c757d;opacity:1}.form-control:-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::placeholder{color:#6c757d;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#e9ecef;opacity:1}select.form-control:focus::-ms-value{color:#495057;background-color:#fff}.form-control-file,.form-control-range{display:block;width:100%}.col-form-label{padding-top:calc(.375rem + 1px);padding-bottom:calc(.375rem + 1px);margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + 1px);padding-bottom:calc(.5rem + 1px);font-size:1.25rem;line-height:1.5}.col-form-label-sm{padding-top:calc(.25rem + 1px);padding-bottom:calc(.25rem + 1px);font-size:.875rem;line-height:1.5}.form-control-plaintext{display:block;width:100%;padding-top:.375rem;padding-bottom:.375rem;margin-bottom:0;line-height:1.5;color:#212529;background-color:transparent;border:solid transparent;border-width:1px 0}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm{padding-right:0;padding-left:0}.form-control-sm{height:calc(1.8125rem + 2px);padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.form-control-lg{height:calc(2.875rem + 2px);padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}select.form-control[multiple],select.form-control[size]{height:auto}textarea.form-control{height:auto}.form-group{margin-bottom:1rem}.form-text{display:block;margin-top:.25rem}.form-row{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.form-row>.col,.form-row>[class*=col-]{padding-right:5px;padding-left:5px}.form-check{position:relative;display:block;padding-left:1.25rem}.form-check-input{position:absolute;margin-top:.3rem;margin-left:-1.25rem}.form-check-input:disabled~.form-check-label{color:#6c757d}.form-check-label{margin-bottom:0}.form-check-inline{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center;padding-left:0;margin-right:.75rem}.form-check-inline .form-check-input{position:static;margin-top:0;margin-right:.3125rem;margin-left:0}.valid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#28a745}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;line-height:1.5;color:#fff;background-color:rgba(40,167,69,.9);border-radius:.25rem}.custom-select.is-valid,.form-control.is-valid,.was-validated .custom-select:valid,.was-validated .form-control:valid{border-color:#28a745}.custom-select.is-valid:focus,.form-control.is-valid:focus,.was-validated .custom-select:valid:focus,.was-validated .form-control:valid:focus{border-color:#28a745;box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.custom-select.is-valid~.valid-feedback,.custom-select.is-valid~.valid-tooltip,.form-control.is-valid~.valid-feedback,.form-control.is-valid~.valid-tooltip,.was-validated .custom-select:valid~.valid-feedback,.was-validated .custom-select:valid~.valid-tooltip,.was-validated .form-control:valid~.valid-feedback,.was-validated .form-control:valid~.valid-tooltip{display:block}.form-control-file.is-valid~.valid-feedback,.form-control-file.is-valid~.valid-tooltip,.was-validated .form-control-file:valid~.valid-feedback,.was-validated .form-control-file:valid~.valid-tooltip{display:block}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:#28a745}.form-check-input.is-valid~.valid-feedback,.form-check-input.is-valid~.valid-tooltip,.was-validated .form-check-input:valid~.valid-feedback,.was-validated .form-check-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid~.custom-control-label,.was-validated .custom-control-input:valid~.custom-control-label{color:#28a745}.custom-control-input.is-valid~.custom-control-label::before,.was-validated .custom-control-input:valid~.custom-control-label::before{background-color:#71dd8a}.custom-control-input.is-valid~.valid-feedback,.custom-control-input.is-valid~.valid-tooltip,.was-validated .custom-control-input:valid~.valid-feedback,.was-validated .custom-control-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid:checked~.custom-control-label::before,.was-validated .custom-control-input:valid:checked~.custom-control-label::before{background-color:#34ce57}.custom-control-input.is-valid:focus~.custom-control-label::before,.was-validated .custom-control-input:valid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(40,167,69,.25)}.custom-file-input.is-valid~.custom-file-label,.was-validated .custom-file-input:valid~.custom-file-label{border-color:#28a745}.custom-file-input.is-valid~.custom-file-label::after,.was-validated .custom-file-input:valid~.custom-file-label::after{border-color:inherit}.custom-file-input.is-valid~.valid-feedback,.custom-file-input.is-valid~.valid-tooltip,.was-validated .custom-file-input:valid~.valid-feedback,.was-validated .custom-file-input:valid~.valid-tooltip{display:block}.custom-file-input.is-valid:focus~.custom-file-label,.was-validated .custom-file-input:valid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.invalid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#dc3545}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;line-height:1.5;color:#fff;background-color:rgba(220,53,69,.9);border-radius:.25rem}.custom-select.is-invalid,.form-control.is-invalid,.was-validated .custom-select:invalid,.was-validated .form-control:invalid{border-color:#dc3545}.custom-select.is-invalid:focus,.form-control.is-invalid:focus,.was-validated .custom-select:invalid:focus,.was-validated .form-control:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.custom-select.is-invalid~.invalid-feedback,.custom-select.is-invalid~.invalid-tooltip,.form-control.is-invalid~.invalid-feedback,.form-control.is-invalid~.invalid-tooltip,.was-validated .custom-select:invalid~.invalid-feedback,.was-validated .custom-select:invalid~.invalid-tooltip,.was-validated .form-control:invalid~.invalid-feedback,.was-validated .form-control:invalid~.invalid-tooltip{display:block}.form-control-file.is-invalid~.invalid-feedback,.form-control-file.is-invalid~.invalid-tooltip,.was-validated .form-control-file:invalid~.invalid-feedback,.was-validated .form-control-file:invalid~.invalid-tooltip{display:block}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:#dc3545}.form-check-input.is-invalid~.invalid-feedback,.form-check-input.is-invalid~.invalid-tooltip,.was-validated .form-check-input:invalid~.invalid-feedback,.was-validated .form-check-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid~.custom-control-label,.was-validated .custom-control-input:invalid~.custom-control-label{color:#dc3545}.custom-control-input.is-invalid~.custom-control-label::before,.was-validated .custom-control-input:invalid~.custom-control-label::before{background-color:#efa2a9}.custom-control-input.is-invalid~.invalid-feedback,.custom-control-input.is-invalid~.invalid-tooltip,.was-validated .custom-control-input:invalid~.invalid-feedback,.was-validated .custom-control-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid:checked~.custom-control-label::before,.was-validated .custom-control-input:invalid:checked~.custom-control-label::before{background-color:#e4606d}.custom-control-input.is-invalid:focus~.custom-control-label::before,.was-validated .custom-control-input:invalid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(220,53,69,.25)}.custom-file-input.is-invalid~.custom-file-label,.was-validated .custom-file-input:invalid~.custom-file-label{border-color:#dc3545}.custom-file-input.is-invalid~.custom-file-label::after,.was-validated .custom-file-input:invalid~.custom-file-label::after{border-color:inherit}.custom-file-input.is-invalid~.invalid-feedback,.custom-file-input.is-invalid~.invalid-tooltip,.was-validated .custom-file-input:invalid~.invalid-feedback,.was-validated .custom-file-input:invalid~.invalid-tooltip{display:block}.custom-file-input.is-invalid:focus~.custom-file-label,.was-validated .custom-file-input:invalid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.form-inline{display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap;-ms-flex-align:center;align-items:center}.form-inline .form-check{width:100%}@media (min-width:576px){.form-inline label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;margin-bottom:0}.form-inline .form-group{display:-ms-flexbox;display:flex;-ms-flex:0 0 auto;flex:0 0 auto;-ms-flex-flow:row wrap;flex-flow:row wrap;-ms-flex-align:center;align-items:center;margin-bottom:0}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-plaintext{display:inline-block}.form-inline .custom-select,.form-inline .input-group{width:auto}.form-inline .form-check{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:auto;padding-left:0}.form-inline .form-check-input{position:relative;margin-top:0;margin-right:.25rem;margin-left:0}.form-inline .custom-control{-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{display:inline-block;font-weight:400;text-align:center;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border:1px solid transparent;padding:.375rem .75rem;font-size:1rem;line-height:1.5;border-radius:.25rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media screen and (prefers-reduced-motion:reduce){.btn{transition:none}}.btn:focus,.btn:hover{text-decoration:none}.btn.focus,.btn:focus{outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.btn.disabled,.btn:disabled{opacity:.65}.btn:not(:disabled):not(.disabled){cursor:pointer}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:hover{color:#fff;background-color:#0069d9;border-color:#0062cc}.btn-primary.focus,.btn-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#0062cc;border-color:#005cbf}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-secondary{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:hover{color:#fff;background-color:#5a6268;border-color:#545b62}.btn-secondary.focus,.btn-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#545b62;border-color:#4e555b}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-success{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:hover{color:#fff;background-color:#218838;border-color:#1e7e34}.btn-success.focus,.btn-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:not(:disabled):not(.disabled).active,.btn-success:not(:disabled):not(.disabled):active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#1e7e34;border-color:#1c7430}.btn-success:not(:disabled):not(.disabled).active:focus,.btn-success:not(:disabled):not(.disabled):active:focus,.show>.btn-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-info{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:hover{color:#fff;background-color:#138496;border-color:#117a8b}.btn-info.focus,.btn-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:not(:disabled):not(.disabled).active,.btn-info:not(:disabled):not(.disabled):active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#117a8b;border-color:#10707f}.btn-info:not(:disabled):not(.disabled).active:focus,.btn-info:not(:disabled):not(.disabled):active:focus,.show>.btn-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-warning{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:hover{color:#212529;background-color:#e0a800;border-color:#d39e00}.btn-warning.focus,.btn-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-warning.disabled,.btn-warning:disabled{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:not(:disabled):not(.disabled).active,.btn-warning:not(:disabled):not(.disabled):active,.show>.btn-warning.dropdown-toggle{color:#212529;background-color:#d39e00;border-color:#c69500}.btn-warning:not(:disabled):not(.disabled).active:focus,.btn-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:hover{color:#fff;background-color:#c82333;border-color:#bd2130}.btn-danger.focus,.btn-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:not(:disabled):not(.disabled).active,.btn-danger:not(:disabled):not(.disabled):active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#bd2130;border-color:#b21f2d}.btn-danger:not(:disabled):not(.disabled).active:focus,.btn-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-light{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:hover{color:#212529;background-color:#e2e6ea;border-color:#dae0e5}.btn-light.focus,.btn-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-light.disabled,.btn-light:disabled{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:not(:disabled):not(.disabled).active,.btn-light:not(:disabled):not(.disabled):active,.show>.btn-light.dropdown-toggle{color:#212529;background-color:#dae0e5;border-color:#d3d9df}.btn-light:not(:disabled):not(.disabled).active:focus,.btn-light:not(:disabled):not(.disabled):active:focus,.show>.btn-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-dark{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:hover{color:#fff;background-color:#23272b;border-color:#1d2124}.btn-dark.focus,.btn-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:not(:disabled):not(.disabled).active,.btn-dark:not(:disabled):not(.disabled):active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#1d2124;border-color:#171a1d}.btn-dark:not(:disabled):not(.disabled).active:focus,.btn-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-primary{color:#007bff;background-color:transparent;background-image:none;border-color:#007bff}.btn-outline-primary:hover{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary.focus,.btn-outline-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#007bff;background-color:transparent}.btn-outline-primary:not(:disabled):not(.disabled).active,.btn-outline-primary:not(:disabled):not(.disabled):active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-secondary{color:#6c757d;background-color:transparent;background-image:none;border-color:#6c757d}.btn-outline-secondary:hover{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary.focus,.btn-outline-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#6c757d;background-color:transparent}.btn-outline-secondary:not(:disabled):not(.disabled).active,.btn-outline-secondary:not(:disabled):not(.disabled):active,.show>.btn-outline-secondary.dropdown-toggle{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-success{color:#28a745;background-color:transparent;background-image:none;border-color:#28a745}.btn-outline-success:hover{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success.focus,.btn-outline-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#28a745;background-color:transparent}.btn-outline-success:not(:disabled):not(.disabled).active,.btn-outline-success:not(:disabled):not(.disabled):active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success:not(:disabled):not(.disabled).active:focus,.btn-outline-success:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-info{color:#17a2b8;background-color:transparent;background-image:none;border-color:#17a2b8}.btn-outline-info:hover{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info.focus,.btn-outline-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#17a2b8;background-color:transparent}.btn-outline-info:not(:disabled):not(.disabled).active,.btn-outline-info:not(:disabled):not(.disabled):active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info:not(:disabled):not(.disabled).active:focus,.btn-outline-info:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-warning{color:#ffc107;background-color:transparent;background-image:none;border-color:#ffc107}.btn-outline-warning:hover{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning.focus,.btn-outline-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#ffc107;background-color:transparent}.btn-outline-warning:not(:disabled):not(.disabled).active,.btn-outline-warning:not(:disabled):not(.disabled):active,.show>.btn-outline-warning.dropdown-toggle{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-danger{color:#dc3545;background-color:transparent;background-image:none;border-color:#dc3545}.btn-outline-danger:hover{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger.focus,.btn-outline-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#dc3545;background-color:transparent}.btn-outline-danger:not(:disabled):not(.disabled).active,.btn-outline-danger:not(:disabled):not(.disabled):active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-light{color:#f8f9fa;background-color:transparent;background-image:none;border-color:#f8f9fa}.btn-outline-light:hover{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light.focus,.btn-outline-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#f8f9fa;background-color:transparent}.btn-outline-light:not(:disabled):not(.disabled).active,.btn-outline-light:not(:disabled):not(.disabled):active,.show>.btn-outline-light.dropdown-toggle{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light:not(:disabled):not(.disabled).active:focus,.btn-outline-light:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-dark{color:#343a40;background-color:transparent;background-image:none;border-color:#343a40}.btn-outline-dark:hover{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark.focus,.btn-outline-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#343a40;background-color:transparent}.btn-outline-dark:not(:disabled):not(.disabled).active,.btn-outline-dark:not(:disabled):not(.disabled):active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-link{font-weight:400;color:#007bff;background-color:transparent}.btn-link:hover{color:#0056b3;text-decoration:underline;background-color:transparent;border-color:transparent}.btn-link.focus,.btn-link:focus{text-decoration:underline;border-color:transparent;box-shadow:none}.btn-link.disabled,.btn-link:disabled{color:#6c757d;pointer-events:none}.btn-group-lg>.btn,.btn-lg{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.btn-group-sm>.btn,.btn-sm{padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:.5rem}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{transition:opacity .15s linear}@media screen and (prefers-reduced-motion:reduce){.fade{transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{position:relative;height:0;overflow:hidden;transition:height .35s ease}@media screen and (prefers-reduced-motion:reduce){.collapsing{transition:none}}.dropdown,.dropleft,.dropright,.dropup{position:relative}.dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid;border-right:.3em solid transparent;border-bottom:0;border-left:.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:10rem;padding:.5rem 0;margin:.125rem 0 0;font-size:1rem;color:#212529;text-align:left;list-style:none;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.15);border-radius:.25rem}.dropdown-menu-right{right:0;left:auto}.dropup .dropdown-menu{top:auto;bottom:100%;margin-top:0;margin-bottom:.125rem}.dropup .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:0;border-right:.3em solid transparent;border-bottom:.3em solid;border-left:.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-menu{top:0;right:auto;left:100%;margin-top:0;margin-left:.125rem}.dropright .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:0;border-bottom:.3em solid transparent;border-left:.3em solid}.dropright .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-toggle::after{vertical-align:0}.dropleft .dropdown-menu{top:0;right:100%;left:auto;margin-top:0;margin-right:.125rem}.dropleft .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:""}.dropleft .dropdown-toggle::after{display:none}.dropleft .dropdown-toggle::before{display:inline-block;width:0;height:0;margin-right:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:.3em solid;border-bottom:.3em solid transparent}.dropleft .dropdown-toggle:empty::after{margin-left:0}.dropleft .dropdown-toggle::before{vertical-align:0}.dropdown-menu[x-placement^=bottom],.dropdown-menu[x-placement^=left],.dropdown-menu[x-placement^=right],.dropdown-menu[x-placement^=top]{right:auto;bottom:auto}.dropdown-divider{height:0;margin:.5rem 0;overflow:hidden;border-top:1px solid #e9ecef}.dropdown-item{display:block;width:100%;padding:.25rem 1.5rem;clear:both;font-weight:400;color:#212529;text-align:inherit;white-space:nowrap;background-color:transparent;border:0}.dropdown-item:focus,.dropdown-item:hover{color:#16181b;text-decoration:none;background-color:#f8f9fa}.dropdown-item.active,.dropdown-item:active{color:#fff;text-decoration:none;background-color:#007bff}.dropdown-item.disabled,.dropdown-item:disabled{color:#6c757d;background-color:transparent}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:.5rem 1.5rem;margin-bottom:0;font-size:.875rem;color:#6c757d;white-space:nowrap}.dropdown-item-text{display:block;padding:.25rem 1.5rem;color:#212529}.btn-group,.btn-group-vertical{position:relative;display:-ms-inline-flexbox;display:inline-flex;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;-ms-flex:0 1 auto;flex:0 1 auto}.btn-group-vertical>.btn:hover,.btn-group>.btn:hover{z-index:1}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus{z-index:1}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group,.btn-group-vertical .btn+.btn,.btn-group-vertical .btn+.btn-group,.btn-group-vertical .btn-group+.btn,.btn-group-vertical .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:start;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:.5625rem;padding-left:.5625rem}.dropdown-toggle-split::after,.dropright .dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after{margin-left:0}.dropleft .dropdown-toggle-split::before{margin-right:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-right:.375rem;padding-left:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-group-vertical{-ms-flex-direction:column;flex-direction:column;-ms-flex-align:start;align-items:flex-start;-ms-flex-pack:center;justify-content:center}.btn-group-vertical .btn,.btn-group-vertical .btn-group{width:100%}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn:not(:first-child){border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type=checkbox],.btn-group-toggle>.btn input[type=radio],.btn-group-toggle>.btn-group>.btn input[type=checkbox],.btn-group-toggle>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:stretch;align-items:stretch;width:100%}.input-group>.custom-file,.input-group>.custom-select,.input-group>.form-control{position:relative;-ms-flex:1 1 auto;flex:1 1 auto;width:1%;margin-bottom:0}.input-group>.custom-file+.custom-file,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.form-control,.input-group>.custom-select+.custom-file,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.form-control,.input-group>.form-control+.custom-file,.input-group>.form-control+.custom-select,.input-group>.form-control+.form-control{margin-left:-1px}.input-group>.custom-file .custom-file-input:focus~.custom-file-label,.input-group>.custom-select:focus,.input-group>.form-control:focus{z-index:3}.input-group>.custom-file .custom-file-input:focus{z-index:4}.input-group>.custom-select:not(:last-child),.input-group>.form-control:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-select:not(:first-child),.input-group>.form-control:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label::after{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-append,.input-group-prepend{display:-ms-flexbox;display:flex}.input-group-append .btn,.input-group-prepend .btn{position:relative;z-index:2}.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.btn,.input-group-append .input-group-text+.input-group-text,.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-prepend .input-group-text+.input-group-text{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;padding:.375rem .75rem;margin-bottom:0;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;text-align:center;white-space:nowrap;background-color:#e9ecef;border:1px solid #ced4da;border-radius:.25rem}.input-group-text input[type=checkbox],.input-group-text input[type=radio]{margin-top:0}.input-group-lg>.form-control,.input-group-lg>.input-group-append>.btn,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-prepend>.input-group-text{height:calc(2.875rem + 2px);padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.input-group-sm>.form-control,.input-group-sm>.input-group-append>.btn,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-prepend>.input-group-text{height:calc(1.8125rem + 2px);padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child),.input-group>.input-group-append:not(:last-child)>.btn,.input-group>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child),.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text{border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{position:relative;display:block;min-height:1.5rem;padding-left:1.5rem}.custom-control-inline{display:-ms-inline-flexbox;display:inline-flex;margin-right:1rem}.custom-control-input{position:absolute;z-index:-1;opacity:0}.custom-control-input:checked~.custom-control-label::before{color:#fff;background-color:#007bff}.custom-control-input:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-control-input:active~.custom-control-label::before{color:#fff;background-color:#b3d7ff}.custom-control-input:disabled~.custom-control-label{color:#6c757d}.custom-control-input:disabled~.custom-control-label::before{background-color:#e9ecef}.custom-control-label{position:relative;margin-bottom:0}.custom-control-label::before{position:absolute;top:.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;pointer-events:none;content:"";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#dee2e6}.custom-control-label::after{position:absolute;top:.25rem;left:-1.5rem;display:block;width:1rem;height:1rem;content:"";background-repeat:no-repeat;background-position:center center;background-size:50% 50%}.custom-checkbox .custom-control-label::before{border-radius:.25rem}.custom-checkbox .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-checkbox .custom-control-input:disabled:indeterminate~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-radio .custom-control-label::before{border-radius:50%}.custom-radio .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-radio .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E")}.custom-radio .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-select{display:inline-block;width:100%;height:calc(2.25rem + 2px);padding:.375rem 1.75rem .375rem .75rem;line-height:1.5;color:#495057;vertical-align:middle;background:#fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right .75rem center;background-size:8px 10px;border:1px solid #ced4da;border-radius:.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem rgba(128,189,255,.5)}.custom-select:focus::-ms-value{color:#495057;background-color:#fff}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;padding-right:.75rem;background-image:none}.custom-select:disabled{color:#6c757d;background-color:#e9ecef}.custom-select::-ms-expand{opacity:0}.custom-select-sm{height:calc(1.8125rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:75%}.custom-select-lg{height:calc(2.875rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:125%}.custom-file{position:relative;display:inline-block;width:100%;height:calc(2.25rem + 2px);margin-bottom:0}.custom-file-input{position:relative;z-index:2;width:100%;height:calc(2.25rem + 2px);margin:0;opacity:0}.custom-file-input:focus~.custom-file-label{border-color:#80bdff;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.custom-file-input:focus~.custom-file-label::after{border-color:#80bdff}.custom-file-input:disabled~.custom-file-label{background-color:#e9ecef}.custom-file-input:lang(en)~.custom-file-label::after{content:"Browse"}.custom-file-label{position:absolute;top:0;right:0;left:0;z-index:1;height:calc(2.25rem + 2px);padding:.375rem .75rem;line-height:1.5;color:#495057;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem}.custom-file-label::after{position:absolute;top:0;right:0;bottom:0;z-index:3;display:block;height:2.25rem;padding:.375rem .75rem;line-height:1.5;color:#495057;content:"Browse";background-color:#e9ecef;border-left:1px solid #ced4da;border-radius:0 .25rem .25rem 0}.custom-range{width:100%;padding-left:0;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-range:focus{outline:0}.custom-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range:focus::-ms-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-range::-moz-focus-outer{border:0}.custom-range::-webkit-slider-thumb{width:1rem;height:1rem;margin-top:-.25rem;background-color:#007bff;border:0;border-radius:1rem;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;-webkit-appearance:none;appearance:none}@media screen and (prefers-reduced-motion:reduce){.custom-range::-webkit-slider-thumb{transition:none}}.custom-range::-webkit-slider-thumb:active{background-color:#b3d7ff}.custom-range::-webkit-slider-runnable-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-moz-range-thumb{width:1rem;height:1rem;background-color:#007bff;border:0;border-radius:1rem;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;-moz-appearance:none;appearance:none}@media screen and (prefers-reduced-motion:reduce){.custom-range::-moz-range-thumb{transition:none}}.custom-range::-moz-range-thumb:active{background-color:#b3d7ff}.custom-range::-moz-range-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:#dee2e6;border-color:transparent;border-radius:1rem}.custom-range::-ms-thumb{width:1rem;height:1rem;margin-top:0;margin-right:.2rem;margin-left:.2rem;background-color:#007bff;border:0;border-radius:1rem;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;appearance:none}@media screen and (prefers-reduced-motion:reduce){.custom-range::-ms-thumb{transition:none}}.custom-range::-ms-thumb:active{background-color:#b3d7ff}.custom-range::-ms-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:transparent;border-color:transparent;border-width:.5rem}.custom-range::-ms-fill-lower{background-color:#dee2e6;border-radius:1rem}.custom-range::-ms-fill-upper{margin-right:15px;background-color:#dee2e6;border-radius:1rem}.custom-control-label::before,.custom-file-label,.custom-select{transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media screen and (prefers-reduced-motion:reduce){.custom-control-label::before,.custom-file-label,.custom-select{transition:none}}.nav{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:.5rem 1rem}.nav-link:focus,.nav-link:hover{text-decoration:none}.nav-link.disabled{color:#6c757d}.nav-tabs{border-bottom:1px solid #dee2e6}.nav-tabs .nav-item{margin-bottom:-1px}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:.25rem;border-top-right-radius:.25rem}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{border-color:#e9ecef #e9ecef #dee2e6}.nav-tabs .nav-link.disabled{color:#6c757d;background-color:transparent;border-color:transparent}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{color:#495057;background-color:#fff;border-color:#dee2e6 #dee2e6 #fff}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.nav-pills .nav-link{border-radius:.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:#fff;background-color:#007bff}.nav-fill .nav-item{-ms-flex:1 1 auto;flex:1 1 auto;text-align:center}.nav-justified .nav-item{-ms-flex-preferred-size:0;flex-basis:0;-ms-flex-positive:1;flex-grow:1;text-align:center}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{position:relative;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;padding:.5rem 1rem}.navbar>.container,.navbar>.container-fluid{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}.navbar-brand{display:inline-block;padding-top:.3125rem;padding-bottom:.3125rem;margin-right:1rem;font-size:1.25rem;line-height:inherit;white-space:nowrap}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-nav{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link{padding-right:0;padding-left:0}.navbar-nav .dropdown-menu{position:static;float:none}.navbar-text{display:inline-block;padding-top:.5rem;padding-bottom:.5rem}.navbar-collapse{-ms-flex-preferred-size:100%;flex-basis:100%;-ms-flex-positive:1;flex-grow:1;-ms-flex-align:center;align-items:center}.navbar-toggler{padding:.25rem .75rem;font-size:1.25rem;line-height:1;background-color:transparent;border:1px solid transparent;border-radius:.25rem}.navbar-toggler:focus,.navbar-toggler:hover{text-decoration:none}.navbar-toggler:not(:disabled):not(.disabled){cursor:pointer}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;content:"";background:no-repeat center center;background-size:100% 100%}@media (max-width:575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:576px){.navbar-expand-sm{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}}@media (max-width:767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:768px){.navbar-expand-md{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-md .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}}@media (max-width:991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:992px){.navbar-expand-lg{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}}@media (max-width:1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:1200px){.navbar-expand-xl{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}}.navbar-expand{-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-right:0;padding-left:0}.navbar-expand .navbar-nav{-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-collapse{display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-light .navbar-brand{color:rgba(0,0,0,.9)}.navbar-light .navbar-brand:focus,.navbar-light .navbar-brand:hover{color:rgba(0,0,0,.9)}.navbar-light .navbar-nav .nav-link{color:rgba(0,0,0,.5)}.navbar-light .navbar-nav .nav-link:focus,.navbar-light .navbar-nav .nav-link:hover{color:rgba(0,0,0,.7)}.navbar-light .navbar-nav .nav-link.disabled{color:rgba(0,0,0,.3)}.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.active,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .show>.nav-link{color:rgba(0,0,0,.9)}.navbar-light .navbar-toggler{color:rgba(0,0,0,.5);border-color:rgba(0,0,0,.1)}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-light .navbar-text{color:rgba(0,0,0,.5)}.navbar-light .navbar-text a{color:rgba(0,0,0,.9)}.navbar-light .navbar-text a:focus,.navbar-light .navbar-text a:hover{color:rgba(0,0,0,.9)}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:focus,.navbar-dark .navbar-brand:hover{color:#fff}.navbar-dark .navbar-nav .nav-link{color:rgba(255,255,255,.5)}.navbar-dark .navbar-nav .nav-link:focus,.navbar-dark .navbar-nav .nav-link:hover{color:rgba(255,255,255,.75)}.navbar-dark .navbar-nav .nav-link.disabled{color:rgba(255,255,255,.25)}.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.active,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .show>.nav-link{color:#fff}.navbar-dark .navbar-toggler{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.1)}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-dark .navbar-text{color:rgba(255,255,255,.5)}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:focus,.navbar-dark .navbar-text a:hover{color:#fff}.card{position:relative;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;min-width:0;word-wrap:break-word;background-color:#fff;background-clip:border-box;border:1px solid rgba(0,0,0,.125);border-radius:.25rem}.card>hr{margin-right:0;margin-left:0}.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-body{-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:.75rem}.card-subtitle{margin-top:-.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{padding:.75rem 1.25rem;margin-bottom:0;background-color:rgba(0,0,0,.03);border-bottom:1px solid rgba(0,0,0,.125)}.card-header:first-child{border-radius:calc(.25rem - 1px) calc(.25rem - 1px) 0 0}.card-header+.list-group .list-group-item:first-child{border-top:0}.card-footer{padding:.75rem 1.25rem;background-color:rgba(0,0,0,.03);border-top:1px solid rgba(0,0,0,.125)}.card-footer:last-child{border-radius:0 0 calc(.25rem - 1px) calc(.25rem - 1px)}.card-header-tabs{margin-right:-.625rem;margin-bottom:-.75rem;margin-left:-.625rem;border-bottom:0}.card-header-pills{margin-right:-.625rem;margin-left:-.625rem}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem}.card-img{width:100%;border-radius:calc(.25rem - 1px)}.card-img-top{width:100%;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card-img-bottom{width:100%;border-bottom-right-radius:calc(.25rem - 1px);border-bottom-left-radius:calc(.25rem - 1px)}.card-deck{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.card-deck .card{margin-bottom:15px}@media (min-width:576px){.card-deck{-ms-flex-flow:row wrap;flex-flow:row wrap;margin-right:-15px;margin-left:-15px}.card-deck .card{display:-ms-flexbox;display:flex;-ms-flex:1 0 0%;flex:1 0 0%;-ms-flex-direction:column;flex-direction:column;margin-right:15px;margin-bottom:0;margin-left:15px}}.card-group{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.card-group>.card{margin-bottom:15px}@media (min-width:576px){.card-group{-ms-flex-flow:row wrap;flex-flow:row wrap}.card-group>.card{-ms-flex:1 0 0%;flex:1 0 0%;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:first-child .card-header,.card-group>.card:first-child .card-img-top{border-top-right-radius:0}.card-group>.card:first-child .card-footer,.card-group>.card:first-child .card-img-bottom{border-bottom-right-radius:0}.card-group>.card:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:last-child .card-header,.card-group>.card:last-child .card-img-top{border-top-left-radius:0}.card-group>.card:last-child .card-footer,.card-group>.card:last-child .card-img-bottom{border-bottom-left-radius:0}.card-group>.card:only-child{border-radius:.25rem}.card-group>.card:only-child .card-header,.card-group>.card:only-child .card-img-top{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card-group>.card:only-child .card-footer,.card-group>.card:only-child .card-img-bottom{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-group>.card:not(:first-child):not(:last-child):not(:only-child){border-radius:0}.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top{border-radius:0}}.card-columns .card{margin-bottom:.75rem}@media (min-width:576px){.card-columns{-webkit-column-count:3;-moz-column-count:3;column-count:3;-webkit-column-gap:1.25rem;-moz-column-gap:1.25rem;column-gap:1.25rem;orphans:1;widows:1}.card-columns .card{display:inline-block;width:100%}}.accordion .card:not(:first-of-type):not(:last-of-type){border-bottom:0;border-radius:0}.accordion .card:not(:first-of-type) .card-header:first-child{border-radius:0}.accordion .card:first-of-type{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.accordion .card:last-of-type{border-top-left-radius:0;border-top-right-radius:0}.breadcrumb{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:.75rem 1rem;margin-bottom:1rem;list-style:none;background-color:#e9ecef;border-radius:.25rem}.breadcrumb-item+.breadcrumb-item{padding-left:.5rem}.breadcrumb-item+.breadcrumb-item::before{display:inline-block;padding-right:.5rem;color:#6c757d;content:"/"}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:none}.breadcrumb-item.active{color:#6c757d}.pagination{display:-ms-flexbox;display:flex;padding-left:0;list-style:none;border-radius:.25rem}.page-link{position:relative;display:block;padding:.5rem .75rem;margin-left:-1px;line-height:1.25;color:#007bff;background-color:#fff;border:1px solid #dee2e6}.page-link:hover{z-index:2;color:#0056b3;text-decoration:none;background-color:#e9ecef;border-color:#dee2e6}.page-link:focus{z-index:2;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.page-link:not(:disabled):not(.disabled){cursor:pointer}.page-item:first-child .page-link{margin-left:0;border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.page-item:last-child .page-link{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.page-item.active .page-link{z-index:1;color:#fff;background-color:#007bff;border-color:#007bff}.page-item.disabled .page-link{color:#6c757d;pointer-events:none;cursor:auto;background-color:#fff;border-color:#dee2e6}.pagination-lg .page-link{padding:.75rem 1.5rem;font-size:1.25rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:.3rem;border-bottom-left-radius:.3rem}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:.3rem;border-bottom-right-radius:.3rem}.pagination-sm .page-link{padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:.2rem;border-bottom-left-radius:.2rem}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:.2rem;border-bottom-right-radius:.2rem}.badge{display:inline-block;padding:.25em .4em;font-size:75%;font-weight:700;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25rem}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{padding-right:.6em;padding-left:.6em;border-radius:10rem}.badge-primary{color:#fff;background-color:#007bff}.badge-primary[href]:focus,.badge-primary[href]:hover{color:#fff;text-decoration:none;background-color:#0062cc}.badge-secondary{color:#fff;background-color:#6c757d}.badge-secondary[href]:focus,.badge-secondary[href]:hover{color:#fff;text-decoration:none;background-color:#545b62}.badge-success{color:#fff;background-color:#28a745}.badge-success[href]:focus,.badge-success[href]:hover{color:#fff;text-decoration:none;background-color:#1e7e34}.badge-info{color:#fff;background-color:#17a2b8}.badge-info[href]:focus,.badge-info[href]:hover{color:#fff;text-decoration:none;background-color:#117a8b}.badge-warning{color:#212529;background-color:#ffc107}.badge-warning[href]:focus,.badge-warning[href]:hover{color:#212529;text-decoration:none;background-color:#d39e00}.badge-danger{color:#fff;background-color:#dc3545}.badge-danger[href]:focus,.badge-danger[href]:hover{color:#fff;text-decoration:none;background-color:#bd2130}.badge-light{color:#212529;background-color:#f8f9fa}.badge-light[href]:focus,.badge-light[href]:hover{color:#212529;text-decoration:none;background-color:#dae0e5}.badge-dark{color:#fff;background-color:#343a40}.badge-dark[href]:focus,.badge-dark[href]:hover{color:#fff;text-decoration:none;background-color:#1d2124}.jumbotron{padding:2rem 1rem;margin-bottom:2rem;background-color:#e9ecef;border-radius:.3rem}@media (min-width:576px){.jumbotron{padding:4rem 2rem}}.jumbotron-fluid{padding-right:0;padding-left:0;border-radius:0}.alert{position:relative;padding:.75rem 1.25rem;margin-bottom:1rem;border:1px solid transparent;border-radius:.25rem}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:4rem}.alert-dismissible .close{position:absolute;top:0;right:0;padding:.75rem 1.25rem;color:inherit}.alert-primary{color:#004085;background-color:#cce5ff;border-color:#b8daff}.alert-primary hr{border-top-color:#9fcdff}.alert-primary .alert-link{color:#002752}.alert-secondary{color:#383d41;background-color:#e2e3e5;border-color:#d6d8db}.alert-secondary hr{border-top-color:#c8cbcf}.alert-secondary .alert-link{color:#202326}.alert-success{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert-success hr{border-top-color:#b1dfbb}.alert-success .alert-link{color:#0b2e13}.alert-info{color:#0c5460;background-color:#d1ecf1;border-color:#bee5eb}.alert-info hr{border-top-color:#abdde5}.alert-info .alert-link{color:#062c33}.alert-warning{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.alert-warning hr{border-top-color:#ffe8a1}.alert-warning .alert-link{color:#533f03}.alert-danger{color:#721c24;background-color:#f8d7da;border-color:#f5c6cb}.alert-danger hr{border-top-color:#f1b0b7}.alert-danger .alert-link{color:#491217}.alert-light{color:#818182;background-color:#fefefe;border-color:#fdfdfe}.alert-light hr{border-top-color:#ececf6}.alert-light .alert-link{color:#686868}.alert-dark{color:#1b1e21;background-color:#d6d8d9;border-color:#c6c8ca}.alert-dark hr{border-top-color:#b9bbbe}.alert-dark .alert-link{color:#040505}@-webkit-keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}.progress{display:-ms-flexbox;display:flex;height:1rem;overflow:hidden;font-size:.75rem;background-color:#e9ecef;border-radius:.25rem}.progress-bar{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;color:#fff;text-align:center;white-space:nowrap;background-color:#007bff;transition:width .6s ease}@media screen and (prefers-reduced-motion:reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}.media{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:flex-start}.media-body{-ms-flex:1;flex:1}.list-group{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0}.list-group-item-action{width:100%;color:#495057;text-align:inherit}.list-group-item-action:focus,.list-group-item-action:hover{color:#495057;text-decoration:none;background-color:#f8f9fa}.list-group-item-action:active{color:#212529;background-color:#e9ecef}.list-group-item{position:relative;display:block;padding:.75rem 1.25rem;margin-bottom:-1px;background-color:#fff;border:1px solid rgba(0,0,0,.125)}.list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.list-group-item:focus,.list-group-item:hover{z-index:1;text-decoration:none}.list-group-item.disabled,.list-group-item:disabled{color:#6c757d;background-color:#fff}.list-group-item.active{z-index:2;color:#fff;background-color:#007bff;border-color:#007bff}.list-group-flush .list-group-item{border-right:0;border-left:0;border-radius:0}.list-group-flush:first-child .list-group-item:first-child{border-top:0}.list-group-flush:last-child .list-group-item:last-child{border-bottom:0}.list-group-item-primary{color:#004085;background-color:#b8daff}.list-group-item-primary.list-group-item-action:focus,.list-group-item-primary.list-group-item-action:hover{color:#004085;background-color:#9fcdff}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#004085;border-color:#004085}.list-group-item-secondary{color:#383d41;background-color:#d6d8db}.list-group-item-secondary.list-group-item-action:focus,.list-group-item-secondary.list-group-item-action:hover{color:#383d41;background-color:#c8cbcf}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#383d41;border-color:#383d41}.list-group-item-success{color:#155724;background-color:#c3e6cb}.list-group-item-success.list-group-item-action:focus,.list-group-item-success.list-group-item-action:hover{color:#155724;background-color:#b1dfbb}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#155724;border-color:#155724}.list-group-item-info{color:#0c5460;background-color:#bee5eb}.list-group-item-info.list-group-item-action:focus,.list-group-item-info.list-group-item-action:hover{color:#0c5460;background-color:#abdde5}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#0c5460;border-color:#0c5460}.list-group-item-warning{color:#856404;background-color:#ffeeba}.list-group-item-warning.list-group-item-action:focus,.list-group-item-warning.list-group-item-action:hover{color:#856404;background-color:#ffe8a1}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#856404;border-color:#856404}.list-group-item-danger{color:#721c24;background-color:#f5c6cb}.list-group-item-danger.list-group-item-action:focus,.list-group-item-danger.list-group-item-action:hover{color:#721c24;background-color:#f1b0b7}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#721c24;border-color:#721c24}.list-group-item-light{color:#818182;background-color:#fdfdfe}.list-group-item-light.list-group-item-action:focus,.list-group-item-light.list-group-item-action:hover{color:#818182;background-color:#ececf6}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#818182;border-color:#818182}.list-group-item-dark{color:#1b1e21;background-color:#c6c8ca}.list-group-item-dark.list-group-item-action:focus,.list-group-item-dark.list-group-item-action:hover{color:#1b1e21;background-color:#b9bbbe}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#1b1e21;border-color:#1b1e21}.close{float:right;font-size:1.5rem;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.5}.close:not(:disabled):not(.disabled){cursor:pointer}.close:not(:disabled):not(.disabled):focus,.close:not(:disabled):not(.disabled):hover{color:#000;text-decoration:none;opacity:.75}button.close{padding:0;background-color:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;outline:0}.modal-dialog{position:relative;width:auto;margin:.5rem;pointer-events:none}.modal.fade .modal-dialog{transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out;-webkit-transform:translate(0,-25%);transform:translate(0,-25%)}@media screen and (prefers-reduced-motion:reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog{-webkit-transform:translate(0,0);transform:translate(0,0)}.modal-dialog-centered{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;min-height:calc(100% - (.5rem * 2))}.modal-dialog-centered::before{display:block;height:calc(100vh - (.5rem * 2));content:""}.modal-content{position:relative;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;width:100%;pointer-events:auto;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem;outline:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:.5}.modal-header{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:flex-start;-ms-flex-pack:justify;justify-content:space-between;padding:1rem;border-bottom:1px solid #e9ecef;border-top-left-radius:.3rem;border-top-right-radius:.3rem}.modal-header .close{padding:1rem;margin:-1rem -1rem -1rem auto}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{position:relative;-ms-flex:1 1 auto;flex:1 1 auto;padding:1rem}.modal-footer{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end;padding:1rem;border-top:1px solid #e9ecef}.modal-footer>:not(:first-child){margin-left:.25rem}.modal-footer>:not(:last-child){margin-right:.25rem}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-centered{min-height:calc(100% - (1.75rem * 2))}.modal-dialog-centered::before{height:calc(100vh - (1.75rem * 2))}.modal-sm{max-width:300px}}@media (min-width:992px){.modal-lg{max-width:800px}}.tooltip{position:absolute;z-index:1070;display:block;margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem}.tooltip .arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-auto[x-placement^=top],.bs-tooltip-top{padding:.4rem 0}.bs-tooltip-auto[x-placement^=top] .arrow,.bs-tooltip-top .arrow{bottom:0}.bs-tooltip-auto[x-placement^=top] .arrow::before,.bs-tooltip-top .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-auto[x-placement^=right],.bs-tooltip-right{padding:0 .4rem}.bs-tooltip-auto[x-placement^=right] .arrow,.bs-tooltip-right .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=right] .arrow::before,.bs-tooltip-right .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-auto[x-placement^=bottom],.bs-tooltip-bottom{padding:.4rem 0}.bs-tooltip-auto[x-placement^=bottom] .arrow,.bs-tooltip-bottom .arrow{top:0}.bs-tooltip-auto[x-placement^=bottom] .arrow::before,.bs-tooltip-bottom .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-auto[x-placement^=left],.bs-tooltip-left{padding:0 .4rem}.bs-tooltip-auto[x-placement^=left] .arrow,.bs-tooltip-left .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=left] .arrow::before,.bs-tooltip-left .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.popover{position:absolute;top:0;left:0;z-index:1060;display:block;max-width:276px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem}.popover .arrow{position:absolute;display:block;width:1rem;height:.5rem;margin:0 .3rem}.popover .arrow::after,.popover .arrow::before{position:absolute;display:block;content:"";border-color:transparent;border-style:solid}.bs-popover-auto[x-placement^=top],.bs-popover-top{margin-bottom:.5rem}.bs-popover-auto[x-placement^=top] .arrow,.bs-popover-top .arrow{bottom:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::after,.bs-popover-top .arrow::before{border-width:.5rem .5rem 0}.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::before{bottom:0;border-top-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-top .arrow::after{bottom:1px;border-top-color:#fff}.bs-popover-auto[x-placement^=right],.bs-popover-right{margin-left:.5rem}.bs-popover-auto[x-placement^=right] .arrow,.bs-popover-right .arrow{left:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::after,.bs-popover-right .arrow::before{border-width:.5rem .5rem .5rem 0}.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::before{left:0;border-right-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-right .arrow::after{left:1px;border-right-color:#fff}.bs-popover-auto[x-placement^=bottom],.bs-popover-bottom{margin-top:.5rem}.bs-popover-auto[x-placement^=bottom] .arrow,.bs-popover-bottom .arrow{top:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::after,.bs-popover-bottom .arrow::before{border-width:0 .5rem .5rem .5rem}.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::before{top:0;border-bottom-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-bottom .arrow::after{top:1px;border-bottom-color:#fff}.bs-popover-auto[x-placement^=bottom] .popover-header::before,.bs-popover-bottom .popover-header::before{position:absolute;top:0;left:50%;display:block;width:1rem;margin-left:-.5rem;content:"";border-bottom:1px solid #f7f7f7}.bs-popover-auto[x-placement^=left],.bs-popover-left{margin-right:.5rem}.bs-popover-auto[x-placement^=left] .arrow,.bs-popover-left .arrow{right:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::after,.bs-popover-left .arrow::before{border-width:.5rem 0 .5rem .5rem}.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::before{right:0;border-left-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-left .arrow::after{right:1px;border-left-color:#fff}.popover-header{padding:.5rem .75rem;margin-bottom:0;font-size:1rem;color:inherit;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px)}.popover-header:empty{display:none}.popover-body{padding:.5rem .75rem;color:#212529}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-item{position:relative;display:none;-ms-flex-align:center;align-items:center;width:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block;transition:-webkit-transform .6s ease;transition:transform .6s ease;transition:transform .6s ease,-webkit-transform .6s ease}@media screen and (prefers-reduced-motion:reduce){.carousel-item-next,.carousel-item-prev,.carousel-item.active{transition:none}}.carousel-item-next,.carousel-item-prev{position:absolute;top:0}.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translateX(0);transform:translateX(0)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.active.carousel-item-right,.carousel-item-next{-webkit-transform:translateX(100%);transform:translateX(100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-right,.carousel-item-next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translateX(-100%);transform:translateX(-100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.carousel-fade .carousel-item{opacity:0;transition-duration:.6s;transition-property:opacity}.carousel-fade .carousel-item-next.carousel-item-left,.carousel-fade .carousel-item-prev.carousel-item-right,.carousel-fade .carousel-item.active{opacity:1}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{opacity:0}.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-prev,.carousel-fade .carousel-item-next,.carousel-fade .carousel-item-prev,.carousel-fade .carousel-item.active{-webkit-transform:translateX(0);transform:translateX(0)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-prev,.carousel-fade .carousel-item-next,.carousel-fade .carousel-item-prev,.carousel-fade .carousel-item.active{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.carousel-control-next,.carousel-control-prev{position:absolute;top:0;bottom:0;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:15%;color:#fff;text-align:center;opacity:.5}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{display:inline-block;width:20px;height:20px;background:transparent no-repeat center center;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E")}.carousel-control-next-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E")}.carousel-indicators{position:absolute;right:0;bottom:10px;left:0;z-index:15;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;padding-left:0;margin-right:15%;margin-left:15%;list-style:none}.carousel-indicators li{position:relative;-ms-flex:0 1 auto;flex:0 1 auto;width:30px;height:3px;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-color:rgba(255,255,255,.5)}.carousel-indicators li::before{position:absolute;top:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators li::after{position:absolute;bottom:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators .active{background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center}.align-baseline{vertical-align:baseline!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.bg-primary{background-color:#007bff!important}a.bg-primary:focus,a.bg-primary:hover,button.bg-primary:focus,button.bg-primary:hover{background-color:#0062cc!important}.bg-secondary{background-color:#6c757d!important}a.bg-secondary:focus,a.bg-secondary:hover,button.bg-secondary:focus,button.bg-secondary:hover{background-color:#545b62!important}.bg-success{background-color:#28a745!important}a.bg-success:focus,a.bg-success:hover,button.bg-success:focus,button.bg-success:hover{background-color:#1e7e34!important}.bg-info{background-color:#17a2b8!important}a.bg-info:focus,a.bg-info:hover,button.bg-info:focus,button.bg-info:hover{background-color:#117a8b!important}.bg-warning{background-color:#ffc107!important}a.bg-warning:focus,a.bg-warning:hover,button.bg-warning:focus,button.bg-warning:hover{background-color:#d39e00!important}.bg-danger{background-color:#dc3545!important}a.bg-danger:focus,a.bg-danger:hover,button.bg-danger:focus,button.bg-danger:hover{background-color:#bd2130!important}.bg-light{background-color:#f8f9fa!important}a.bg-light:focus,a.bg-light:hover,button.bg-light:focus,button.bg-light:hover{background-color:#dae0e5!important}.bg-dark{background-color:#343a40!important}a.bg-dark:focus,a.bg-dark:hover,button.bg-dark:focus,button.bg-dark:hover{background-color:#1d2124!important}.bg-white{background-color:#fff!important}.bg-transparent{background-color:transparent!important}.border{border:1px solid #dee2e6!important}.border-top{border-top:1px solid #dee2e6!important}.border-right{border-right:1px solid #dee2e6!important}.border-bottom{border-bottom:1px solid #dee2e6!important}.border-left{border-left:1px solid #dee2e6!important}.border-0{border:0!important}.border-top-0{border-top:0!important}.border-right-0{border-right:0!important}.border-bottom-0{border-bottom:0!important}.border-left-0{border-left:0!important}.border-primary{border-color:#007bff!important}.border-secondary{border-color:#6c757d!important}.border-success{border-color:#28a745!important}.border-info{border-color:#17a2b8!important}.border-warning{border-color:#ffc107!important}.border-danger{border-color:#dc3545!important}.border-light{border-color:#f8f9fa!important}.border-dark{border-color:#343a40!important}.border-white{border-color:#fff!important}.rounded{border-radius:.25rem!important}.rounded-top{border-top-left-radius:.25rem!important;border-top-right-radius:.25rem!important}.rounded-right{border-top-right-radius:.25rem!important;border-bottom-right-radius:.25rem!important}.rounded-bottom{border-bottom-right-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-left{border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-circle{border-radius:50%!important}.rounded-0{border-radius:0!important}.clearfix::after{display:block;clear:both;content:""}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:-ms-flexbox!important;display:flex!important}.d-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}@media (min-width:576px){.d-sm-none{display:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:-ms-flexbox!important;display:flex!important}.d-sm-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:768px){.d-md-none{display:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:-ms-flexbox!important;display:flex!important}.d-md-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:992px){.d-lg-none{display:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:-ms-flexbox!important;display:flex!important}.d-lg-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:1200px){.d-xl-none{display:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:-ms-flexbox!important;display:flex!important}.d-xl-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}@media print{.d-print-none{display:none!important}.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:-ms-flexbox!important;display:flex!important}.d-print-inline-flex{display:-ms-inline-flexbox!important;display:inline-flex!important}}.embed-responsive{position:relative;display:block;width:100%;padding:0;overflow:hidden}.embed-responsive::before{display:block;content:""}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-21by9::before{padding-top:42.857143%}.embed-responsive-16by9::before{padding-top:56.25%}.embed-responsive-4by3::before{padding-top:75%}.embed-responsive-1by1::before{padding-top:100%}.flex-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-center{-ms-flex-align:center!important;align-items:center!important}.align-items-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}@media (min-width:576px){.flex-sm-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-sm-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-sm-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-sm-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-sm-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-sm-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-sm-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-sm-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-sm-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-sm-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-sm-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-sm-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-sm-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-sm-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-sm-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-sm-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-sm-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-sm-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-sm-center{-ms-flex-align:center!important;align-items:center!important}.align-items-sm-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-sm-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-sm-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-sm-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-sm-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-sm-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-sm-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-sm-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-sm-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-sm-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-sm-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-sm-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-sm-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-sm-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:768px){.flex-md-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-md-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-md-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-md-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-md-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-md-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-md-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-md-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-md-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-md-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-md-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-md-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-md-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-md-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-md-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-md-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-md-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-md-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-md-center{-ms-flex-align:center!important;align-items:center!important}.align-items-md-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-md-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-md-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-md-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-md-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-md-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-md-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-md-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-md-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-md-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-md-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-md-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-md-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-md-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:992px){.flex-lg-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-lg-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-lg-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-lg-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-lg-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-lg-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-lg-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-lg-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-lg-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-lg-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-lg-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-lg-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-lg-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-lg-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-lg-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-lg-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-lg-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-lg-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-lg-center{-ms-flex-align:center!important;align-items:center!important}.align-items-lg-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-lg-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-lg-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-lg-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-lg-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-lg-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-lg-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-lg-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-lg-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-lg-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-lg-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-lg-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-lg-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-lg-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:1200px){.flex-xl-row{-ms-flex-direction:row!important;flex-direction:row!important}.flex-xl-column{-ms-flex-direction:column!important;flex-direction:column!important}.flex-xl-row-reverse{-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-xl-column-reverse{-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-xl-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-xl-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.flex-xl-fill{-ms-flex:1 1 auto!important;flex:1 1 auto!important}.flex-xl-grow-0{-ms-flex-positive:0!important;flex-grow:0!important}.flex-xl-grow-1{-ms-flex-positive:1!important;flex-grow:1!important}.flex-xl-shrink-0{-ms-flex-negative:0!important;flex-shrink:0!important}.flex-xl-shrink-1{-ms-flex-negative:1!important;flex-shrink:1!important}.justify-content-xl-start{-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-xl-end{-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-xl-center{-ms-flex-pack:center!important;justify-content:center!important}.justify-content-xl-between{-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-xl-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-xl-start{-ms-flex-align:start!important;align-items:flex-start!important}.align-items-xl-end{-ms-flex-align:end!important;align-items:flex-end!important}.align-items-xl-center{-ms-flex-align:center!important;align-items:center!important}.align-items-xl-baseline{-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-xl-stretch{-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-xl-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-xl-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-xl-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-xl-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-xl-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-xl-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-xl-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-xl-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-xl-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-xl-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-xl-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-xl-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}.float-left{float:left!important}.float-right{float:right!important}.float-none{float:none!important}@media (min-width:576px){.float-sm-left{float:left!important}.float-sm-right{float:right!important}.float-sm-none{float:none!important}}@media (min-width:768px){.float-md-left{float:left!important}.float-md-right{float:right!important}.float-md-none{float:none!important}}@media (min-width:992px){.float-lg-left{float:left!important}.float-lg-right{float:right!important}.float-lg-none{float:none!important}}@media (min-width:1200px){.float-xl-left{float:left!important}.float-xl-right{float:right!important}.float-xl-none{float:none!important}}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}@supports ((position:-webkit-sticky) or (position:sticky)){.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.shadow-sm{box-shadow:0 .125rem .25rem rgba(0,0,0,.075)!important}.shadow{box-shadow:0 .5rem 1rem rgba(0,0,0,.15)!important}.shadow-lg{box-shadow:0 1rem 3rem rgba(0,0,0,.175)!important}.shadow-none{box-shadow:none!important}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.w-auto{width:auto!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.h-auto{height:auto!important}.mw-100{max-width:100%!important}.mh-100{max-height:100%!important}.m-0{margin:0!important}.mt-0,.my-0{margin-top:0!important}.mr-0,.mx-0{margin-right:0!important}.mb-0,.my-0{margin-bottom:0!important}.ml-0,.mx-0{margin-left:0!important}.m-1{margin:.25rem!important}.mt-1,.my-1{margin-top:.25rem!important}.mr-1,.mx-1{margin-right:.25rem!important}.mb-1,.my-1{margin-bottom:.25rem!important}.ml-1,.mx-1{margin-left:.25rem!important}.m-2{margin:.5rem!important}.mt-2,.my-2{margin-top:.5rem!important}.mr-2,.mx-2{margin-right:.5rem!important}.mb-2,.my-2{margin-bottom:.5rem!important}.ml-2,.mx-2{margin-left:.5rem!important}.m-3{margin:1rem!important}.mt-3,.my-3{margin-top:1rem!important}.mr-3,.mx-3{margin-right:1rem!important}.mb-3,.my-3{margin-bottom:1rem!important}.ml-3,.mx-3{margin-left:1rem!important}.m-4{margin:1.5rem!important}.mt-4,.my-4{margin-top:1.5rem!important}.mr-4,.mx-4{margin-right:1.5rem!important}.mb-4,.my-4{margin-bottom:1.5rem!important}.ml-4,.mx-4{margin-left:1.5rem!important}.m-5{margin:3rem!important}.mt-5,.my-5{margin-top:3rem!important}.mr-5,.mx-5{margin-right:3rem!important}.mb-5,.my-5{margin-bottom:3rem!important}.ml-5,.mx-5{margin-left:3rem!important}.p-0{padding:0!important}.pt-0,.py-0{padding-top:0!important}.pr-0,.px-0{padding-right:0!important}.pb-0,.py-0{padding-bottom:0!important}.pl-0,.px-0{padding-left:0!important}.p-1{padding:.25rem!important}.pt-1,.py-1{padding-top:.25rem!important}.pr-1,.px-1{padding-right:.25rem!important}.pb-1,.py-1{padding-bottom:.25rem!important}.pl-1,.px-1{padding-left:.25rem!important}.p-2{padding:.5rem!important}.pt-2,.py-2{padding-top:.5rem!important}.pr-2,.px-2{padding-right:.5rem!important}.pb-2,.py-2{padding-bottom:.5rem!important}.pl-2,.px-2{padding-left:.5rem!important}.p-3{padding:1rem!important}.pt-3,.py-3{padding-top:1rem!important}.pr-3,.px-3{padding-right:1rem!important}.pb-3,.py-3{padding-bottom:1rem!important}.pl-3,.px-3{padding-left:1rem!important}.p-4{padding:1.5rem!important}.pt-4,.py-4{padding-top:1.5rem!important}.pr-4,.px-4{padding-right:1.5rem!important}.pb-4,.py-4{padding-bottom:1.5rem!important}.pl-4,.px-4{padding-left:1.5rem!important}.p-5{padding:3rem!important}.pt-5,.py-5{padding-top:3rem!important}.pr-5,.px-5{padding-right:3rem!important}.pb-5,.py-5{padding-bottom:3rem!important}.pl-5,.px-5{padding-left:3rem!important}.m-auto{margin:auto!important}.mt-auto,.my-auto{margin-top:auto!important}.mr-auto,.mx-auto{margin-right:auto!important}.mb-auto,.my-auto{margin-bottom:auto!important}.ml-auto,.mx-auto{margin-left:auto!important}@media (min-width:576px){.m-sm-0{margin:0!important}.mt-sm-0,.my-sm-0{margin-top:0!important}.mr-sm-0,.mx-sm-0{margin-right:0!important}.mb-sm-0,.my-sm-0{margin-bottom:0!important}.ml-sm-0,.mx-sm-0{margin-left:0!important}.m-sm-1{margin:.25rem!important}.mt-sm-1,.my-sm-1{margin-top:.25rem!important}.mr-sm-1,.mx-sm-1{margin-right:.25rem!important}.mb-sm-1,.my-sm-1{margin-bottom:.25rem!important}.ml-sm-1,.mx-sm-1{margin-left:.25rem!important}.m-sm-2{margin:.5rem!important}.mt-sm-2,.my-sm-2{margin-top:.5rem!important}.mr-sm-2,.mx-sm-2{margin-right:.5rem!important}.mb-sm-2,.my-sm-2{margin-bottom:.5rem!important}.ml-sm-2,.mx-sm-2{margin-left:.5rem!important}.m-sm-3{margin:1rem!important}.mt-sm-3,.my-sm-3{margin-top:1rem!important}.mr-sm-3,.mx-sm-3{margin-right:1rem!important}.mb-sm-3,.my-sm-3{margin-bottom:1rem!important}.ml-sm-3,.mx-sm-3{margin-left:1rem!important}.m-sm-4{margin:1.5rem!important}.mt-sm-4,.my-sm-4{margin-top:1.5rem!important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem!important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem!important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem!important}.m-sm-5{margin:3rem!important}.mt-sm-5,.my-sm-5{margin-top:3rem!important}.mr-sm-5,.mx-sm-5{margin-right:3rem!important}.mb-sm-5,.my-sm-5{margin-bottom:3rem!important}.ml-sm-5,.mx-sm-5{margin-left:3rem!important}.p-sm-0{padding:0!important}.pt-sm-0,.py-sm-0{padding-top:0!important}.pr-sm-0,.px-sm-0{padding-right:0!important}.pb-sm-0,.py-sm-0{padding-bottom:0!important}.pl-sm-0,.px-sm-0{padding-left:0!important}.p-sm-1{padding:.25rem!important}.pt-sm-1,.py-sm-1{padding-top:.25rem!important}.pr-sm-1,.px-sm-1{padding-right:.25rem!important}.pb-sm-1,.py-sm-1{padding-bottom:.25rem!important}.pl-sm-1,.px-sm-1{padding-left:.25rem!important}.p-sm-2{padding:.5rem!important}.pt-sm-2,.py-sm-2{padding-top:.5rem!important}.pr-sm-2,.px-sm-2{padding-right:.5rem!important}.pb-sm-2,.py-sm-2{padding-bottom:.5rem!important}.pl-sm-2,.px-sm-2{padding-left:.5rem!important}.p-sm-3{padding:1rem!important}.pt-sm-3,.py-sm-3{padding-top:1rem!important}.pr-sm-3,.px-sm-3{padding-right:1rem!important}.pb-sm-3,.py-sm-3{padding-bottom:1rem!important}.pl-sm-3,.px-sm-3{padding-left:1rem!important}.p-sm-4{padding:1.5rem!important}.pt-sm-4,.py-sm-4{padding-top:1.5rem!important}.pr-sm-4,.px-sm-4{padding-right:1.5rem!important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem!important}.pl-sm-4,.px-sm-4{padding-left:1.5rem!important}.p-sm-5{padding:3rem!important}.pt-sm-5,.py-sm-5{padding-top:3rem!important}.pr-sm-5,.px-sm-5{padding-right:3rem!important}.pb-sm-5,.py-sm-5{padding-bottom:3rem!important}.pl-sm-5,.px-sm-5{padding-left:3rem!important}.m-sm-auto{margin:auto!important}.mt-sm-auto,.my-sm-auto{margin-top:auto!important}.mr-sm-auto,.mx-sm-auto{margin-right:auto!important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto!important}.ml-sm-auto,.mx-sm-auto{margin-left:auto!important}}@media (min-width:768px){.m-md-0{margin:0!important}.mt-md-0,.my-md-0{margin-top:0!important}.mr-md-0,.mx-md-0{margin-right:0!important}.mb-md-0,.my-md-0{margin-bottom:0!important}.ml-md-0,.mx-md-0{margin-left:0!important}.m-md-1{margin:.25rem!important}.mt-md-1,.my-md-1{margin-top:.25rem!important}.mr-md-1,.mx-md-1{margin-right:.25rem!important}.mb-md-1,.my-md-1{margin-bottom:.25rem!important}.ml-md-1,.mx-md-1{margin-left:.25rem!important}.m-md-2{margin:.5rem!important}.mt-md-2,.my-md-2{margin-top:.5rem!important}.mr-md-2,.mx-md-2{margin-right:.5rem!important}.mb-md-2,.my-md-2{margin-bottom:.5rem!important}.ml-md-2,.mx-md-2{margin-left:.5rem!important}.m-md-3{margin:1rem!important}.mt-md-3,.my-md-3{margin-top:1rem!important}.mr-md-3,.mx-md-3{margin-right:1rem!important}.mb-md-3,.my-md-3{margin-bottom:1rem!important}.ml-md-3,.mx-md-3{margin-left:1rem!important}.m-md-4{margin:1.5rem!important}.mt-md-4,.my-md-4{margin-top:1.5rem!important}.mr-md-4,.mx-md-4{margin-right:1.5rem!important}.mb-md-4,.my-md-4{margin-bottom:1.5rem!important}.ml-md-4,.mx-md-4{margin-left:1.5rem!important}.m-md-5{margin:3rem!important}.mt-md-5,.my-md-5{margin-top:3rem!important}.mr-md-5,.mx-md-5{margin-right:3rem!important}.mb-md-5,.my-md-5{margin-bottom:3rem!important}.ml-md-5,.mx-md-5{margin-left:3rem!important}.p-md-0{padding:0!important}.pt-md-0,.py-md-0{padding-top:0!important}.pr-md-0,.px-md-0{padding-right:0!important}.pb-md-0,.py-md-0{padding-bottom:0!important}.pl-md-0,.px-md-0{padding-left:0!important}.p-md-1{padding:.25rem!important}.pt-md-1,.py-md-1{padding-top:.25rem!important}.pr-md-1,.px-md-1{padding-right:.25rem!important}.pb-md-1,.py-md-1{padding-bottom:.25rem!important}.pl-md-1,.px-md-1{padding-left:.25rem!important}.p-md-2{padding:.5rem!important}.pt-md-2,.py-md-2{padding-top:.5rem!important}.pr-md-2,.px-md-2{padding-right:.5rem!important}.pb-md-2,.py-md-2{padding-bottom:.5rem!important}.pl-md-2,.px-md-2{padding-left:.5rem!important}.p-md-3{padding:1rem!important}.pt-md-3,.py-md-3{padding-top:1rem!important}.pr-md-3,.px-md-3{padding-right:1rem!important}.pb-md-3,.py-md-3{padding-bottom:1rem!important}.pl-md-3,.px-md-3{padding-left:1rem!important}.p-md-4{padding:1.5rem!important}.pt-md-4,.py-md-4{padding-top:1.5rem!important}.pr-md-4,.px-md-4{padding-right:1.5rem!important}.pb-md-4,.py-md-4{padding-bottom:1.5rem!important}.pl-md-4,.px-md-4{padding-left:1.5rem!important}.p-md-5{padding:3rem!important}.pt-md-5,.py-md-5{padding-top:3rem!important}.pr-md-5,.px-md-5{padding-right:3rem!important}.pb-md-5,.py-md-5{padding-bottom:3rem!important}.pl-md-5,.px-md-5{padding-left:3rem!important}.m-md-auto{margin:auto!important}.mt-md-auto,.my-md-auto{margin-top:auto!important}.mr-md-auto,.mx-md-auto{margin-right:auto!important}.mb-md-auto,.my-md-auto{margin-bottom:auto!important}.ml-md-auto,.mx-md-auto{margin-left:auto!important}}@media (min-width:992px){.m-lg-0{margin:0!important}.mt-lg-0,.my-lg-0{margin-top:0!important}.mr-lg-0,.mx-lg-0{margin-right:0!important}.mb-lg-0,.my-lg-0{margin-bottom:0!important}.ml-lg-0,.mx-lg-0{margin-left:0!important}.m-lg-1{margin:.25rem!important}.mt-lg-1,.my-lg-1{margin-top:.25rem!important}.mr-lg-1,.mx-lg-1{margin-right:.25rem!important}.mb-lg-1,.my-lg-1{margin-bottom:.25rem!important}.ml-lg-1,.mx-lg-1{margin-left:.25rem!important}.m-lg-2{margin:.5rem!important}.mt-lg-2,.my-lg-2{margin-top:.5rem!important}.mr-lg-2,.mx-lg-2{margin-right:.5rem!important}.mb-lg-2,.my-lg-2{margin-bottom:.5rem!important}.ml-lg-2,.mx-lg-2{margin-left:.5rem!important}.m-lg-3{margin:1rem!important}.mt-lg-3,.my-lg-3{margin-top:1rem!important}.mr-lg-3,.mx-lg-3{margin-right:1rem!important}.mb-lg-3,.my-lg-3{margin-bottom:1rem!important}.ml-lg-3,.mx-lg-3{margin-left:1rem!important}.m-lg-4{margin:1.5rem!important}.mt-lg-4,.my-lg-4{margin-top:1.5rem!important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem!important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem!important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem!important}.m-lg-5{margin:3rem!important}.mt-lg-5,.my-lg-5{margin-top:3rem!important}.mr-lg-5,.mx-lg-5{margin-right:3rem!important}.mb-lg-5,.my-lg-5{margin-bottom:3rem!important}.ml-lg-5,.mx-lg-5{margin-left:3rem!important}.p-lg-0{padding:0!important}.pt-lg-0,.py-lg-0{padding-top:0!important}.pr-lg-0,.px-lg-0{padding-right:0!important}.pb-lg-0,.py-lg-0{padding-bottom:0!important}.pl-lg-0,.px-lg-0{padding-left:0!important}.p-lg-1{padding:.25rem!important}.pt-lg-1,.py-lg-1{padding-top:.25rem!important}.pr-lg-1,.px-lg-1{padding-right:.25rem!important}.pb-lg-1,.py-lg-1{padding-bottom:.25rem!important}.pl-lg-1,.px-lg-1{padding-left:.25rem!important}.p-lg-2{padding:.5rem!important}.pt-lg-2,.py-lg-2{padding-top:.5rem!important}.pr-lg-2,.px-lg-2{padding-right:.5rem!important}.pb-lg-2,.py-lg-2{padding-bottom:.5rem!important}.pl-lg-2,.px-lg-2{padding-left:.5rem!important}.p-lg-3{padding:1rem!important}.pt-lg-3,.py-lg-3{padding-top:1rem!important}.pr-lg-3,.px-lg-3{padding-right:1rem!important}.pb-lg-3,.py-lg-3{padding-bottom:1rem!important}.pl-lg-3,.px-lg-3{padding-left:1rem!important}.p-lg-4{padding:1.5rem!important}.pt-lg-4,.py-lg-4{padding-top:1.5rem!important}.pr-lg-4,.px-lg-4{padding-right:1.5rem!important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem!important}.pl-lg-4,.px-lg-4{padding-left:1.5rem!important}.p-lg-5{padding:3rem!important}.pt-lg-5,.py-lg-5{padding-top:3rem!important}.pr-lg-5,.px-lg-5{padding-right:3rem!important}.pb-lg-5,.py-lg-5{padding-bottom:3rem!important}.pl-lg-5,.px-lg-5{padding-left:3rem!important}.m-lg-auto{margin:auto!important}.mt-lg-auto,.my-lg-auto{margin-top:auto!important}.mr-lg-auto,.mx-lg-auto{margin-right:auto!important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto!important}.ml-lg-auto,.mx-lg-auto{margin-left:auto!important}}@media (min-width:1200px){.m-xl-0{margin:0!important}.mt-xl-0,.my-xl-0{margin-top:0!important}.mr-xl-0,.mx-xl-0{margin-right:0!important}.mb-xl-0,.my-xl-0{margin-bottom:0!important}.ml-xl-0,.mx-xl-0{margin-left:0!important}.m-xl-1{margin:.25rem!important}.mt-xl-1,.my-xl-1{margin-top:.25rem!important}.mr-xl-1,.mx-xl-1{margin-right:.25rem!important}.mb-xl-1,.my-xl-1{margin-bottom:.25rem!important}.ml-xl-1,.mx-xl-1{margin-left:.25rem!important}.m-xl-2{margin:.5rem!important}.mt-xl-2,.my-xl-2{margin-top:.5rem!important}.mr-xl-2,.mx-xl-2{margin-right:.5rem!important}.mb-xl-2,.my-xl-2{margin-bottom:.5rem!important}.ml-xl-2,.mx-xl-2{margin-left:.5rem!important}.m-xl-3{margin:1rem!important}.mt-xl-3,.my-xl-3{margin-top:1rem!important}.mr-xl-3,.mx-xl-3{margin-right:1rem!important}.mb-xl-3,.my-xl-3{margin-bottom:1rem!important}.ml-xl-3,.mx-xl-3{margin-left:1rem!important}.m-xl-4{margin:1.5rem!important}.mt-xl-4,.my-xl-4{margin-top:1.5rem!important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem!important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem!important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem!important}.m-xl-5{margin:3rem!important}.mt-xl-5,.my-xl-5{margin-top:3rem!important}.mr-xl-5,.mx-xl-5{margin-right:3rem!important}.mb-xl-5,.my-xl-5{margin-bottom:3rem!important}.ml-xl-5,.mx-xl-5{margin-left:3rem!important}.p-xl-0{padding:0!important}.pt-xl-0,.py-xl-0{padding-top:0!important}.pr-xl-0,.px-xl-0{padding-right:0!important}.pb-xl-0,.py-xl-0{padding-bottom:0!important}.pl-xl-0,.px-xl-0{padding-left:0!important}.p-xl-1{padding:.25rem!important}.pt-xl-1,.py-xl-1{padding-top:.25rem!important}.pr-xl-1,.px-xl-1{padding-right:.25rem!important}.pb-xl-1,.py-xl-1{padding-bottom:.25rem!important}.pl-xl-1,.px-xl-1{padding-left:.25rem!important}.p-xl-2{padding:.5rem!important}.pt-xl-2,.py-xl-2{padding-top:.5rem!important}.pr-xl-2,.px-xl-2{padding-right:.5rem!important}.pb-xl-2,.py-xl-2{padding-bottom:.5rem!important}.pl-xl-2,.px-xl-2{padding-left:.5rem!important}.p-xl-3{padding:1rem!important}.pt-xl-3,.py-xl-3{padding-top:1rem!important}.pr-xl-3,.px-xl-3{padding-right:1rem!important}.pb-xl-3,.py-xl-3{padding-bottom:1rem!important}.pl-xl-3,.px-xl-3{padding-left:1rem!important}.p-xl-4{padding:1.5rem!important}.pt-xl-4,.py-xl-4{padding-top:1.5rem!important}.pr-xl-4,.px-xl-4{padding-right:1.5rem!important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem!important}.pl-xl-4,.px-xl-4{padding-left:1.5rem!important}.p-xl-5{padding:3rem!important}.pt-xl-5,.py-xl-5{padding-top:3rem!important}.pr-xl-5,.px-xl-5{padding-right:3rem!important}.pb-xl-5,.py-xl-5{padding-bottom:3rem!important}.pl-xl-5,.px-xl-5{padding-left:3rem!important}.m-xl-auto{margin:auto!important}.mt-xl-auto,.my-xl-auto{margin-top:auto!important}.mr-xl-auto,.mx-xl-auto{margin-right:auto!important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto!important}.ml-xl-auto,.mx-xl-auto{margin-left:auto!important}}.text-monospace{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}.text-justify{text-align:justify!important}.text-nowrap{white-space:nowrap!important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}@media (min-width:576px){.text-sm-left{text-align:left!important}.text-sm-right{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.text-md-left{text-align:left!important}.text-md-right{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.text-lg-left{text-align:left!important}.text-lg-right{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.text-xl-left{text-align:left!important}.text-xl-right{text-align:right!important}.text-xl-center{text-align:center!important}}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.font-weight-light{font-weight:300!important}.font-weight-normal{font-weight:400!important}.font-weight-bold{font-weight:700!important}.font-italic{font-style:italic!important}.text-white{color:#fff!important}.text-primary{color:#007bff!important}a.text-primary:focus,a.text-primary:hover{color:#0062cc!important}.text-secondary{color:#6c757d!important}a.text-secondary:focus,a.text-secondary:hover{color:#545b62!important}.text-success{color:#28a745!important}a.text-success:focus,a.text-success:hover{color:#1e7e34!important}.text-info{color:#17a2b8!important}a.text-info:focus,a.text-info:hover{color:#117a8b!important}.text-warning{color:#ffc107!important}a.text-warning:focus,a.text-warning:hover{color:#d39e00!important}.text-danger{color:#dc3545!important}a.text-danger:focus,a.text-danger:hover{color:#bd2130!important}.text-light{color:#f8f9fa!important}a.text-light:focus,a.text-light:hover{color:#dae0e5!important}.text-dark{color:#343a40!important}a.text-dark:focus,a.text-dark:hover{color:#1d2124!important}.text-body{color:#212529!important}.text-muted{color:#6c757d!important}.text-black-50{color:rgba(0,0,0,.5)!important}.text-white-50{color:rgba(255,255,255,.5)!important}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.visible{visibility:visible!important}.invisible{visibility:hidden!important}@media print{*,::after,::before{text-shadow:none!important;box-shadow:none!important}a:not(.btn){text-decoration:underline}abbr[title]::after{content:" (" attr(title) ")"}pre{white-space:pre-wrap!important}blockquote,pre{border:1px solid #adb5bd;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body{min-width:992px!important}.container{min-width:992px!important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #dee2e6!important}.table-dark{color:inherit}.table-dark tbody+tbody,.table-dark td,.table-dark th,.table-dark thead th{border-color:#dee2e6}.table .thead-dark th{color:inherit;border-color:#dee2e6}}
/*# sourceMappingURL=bootstrap.min.css.map */
</style>

</head>

<body class='bg-light'>
<div class='container-fluid' style='text-align: center;'>



<a name='layout1'/><h4>系统管理</h4>
<svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'   width='1376' height='1246' viewBox='0 0 1376 1246' >
  <script type='text/ecmascript'>
  <![CDATA[
  function hghl(el) { for ( var i in el ){ var elem = document.getElementById(el[i]); if ( elem != null ) elem.setAttribute('class','highlight');  }  }
  function uhghl(el) { for ( var i in el ){ var elem = document.getElementById(el[i]); if ( elem != null ) elem.setAttribute('class','scene'); }  } 
  ]]>
  </script> 

<style type='text/css'>
  text                { fill:#000000; font-family: System, 'Trebuchet MS', Dialog; font-size:12px; }
  a text:hover        { fill:#94025f; text-shadow: 0px 0px 6px #d0ce00; font-size:13px; }
  text.highlight      { fill:#94025f; text-shadow: 0px 0px 4px #eac533; font-size:13px; }
  text.white          { fill:#ffffff; }
  text.colType        { fill:#b3b3b3; }
  text.relName        { fill:#b09c7c; }
  path                { stroke:#5c554f; stroke-width:1.15; fill:none;}
  path                { stroke:#5c554f; stroke-width:1.15; fill:none;}
  path.virtual        { stroke:#b7642d; }
  path.logo           { fill:#fbeac0;fill-opacity:1;stroke-width:0.3;stroke:#222222; }
  path.dotted         { stroke-dasharray:4,2; }
  path.scene          { stroke-width:10; opacity:0;}
  path.highlight      { stroke-width:5; stroke:#c1a662; opacity:0.6;}
  rect.entity         { fill:#ffffff; stroke:#aaa; stroke-width:1;shape-rendering:crispEdges; filter:url(#shadow); }
  line.delim          { stroke-width:1; shape-rendering:crispEdges; }
  text.callout        { fill:#000000; font-family: System, 'Trebuchet MS', Dialog; font-size:12px; }
  rect.callout        { fill:url(#calloutGradient); stroke:#bebdbd; stroke-width:0.5; }
  rect.grp            { stroke:#b1b1b1; stroke-width:1.7; opacity:0.8; }
  path.st0            { fill:#ececec;fill-opacity:1;stroke-width:0.6;stroke:#d0d0d0; }
</style>
<defs>
  <pattern id='layoutBgA'  width='10' height='20' x='0' y='0' viewBox='0 0 5 10'>  
     <line x1='-2' y1='1' x2='7' y2='10' stroke='#f3f3f3' stroke-width='.5'/>  
     <line x1='-2' y1='6' x2='7' y2='15' stroke='#f3f3f3' stroke-width='.5'/>  
     <line x1='-2' y1='-4' x2='7' y2='5' stroke='#f3f3f3' stroke-width='.5'/>  
  </pattern>  
  <radialGradient id='layoutBgB'  cx='50%' cy='50%' r='75%' fx='46%' fy='22%'>
     <stop offset='0%' stop-opacity='.2' stop-color='#f2f2f2' />  
     <stop offset='100%' stop-color='#eaeaea' />  
  </radialGradient>
  <pattern id='layoutBgTr'  width='300' height='300' x='0' y='0' viewBox='0 0 300 300'>  
  <path class='st0' d='m 62.011835,91.267143 c 3.536475,3.175214 2.262669,8.705999 -1.637711,11.015197 -3.594697,5.8423 -6.34682,-2.892623 -9.715478,-4.653898 -5.609222,-2.838926 2.050802,-6.680123 4.77004,-8.319046 2.334696,-0.724067 4.935143,0.312302 6.583149,1.957747 z m -2.720492,2.538595 c -2.698397,-3.517732 -9.282815,1.269287 -3.69635,3.568637 2.765331,5.605665 7.052809,-0.56184 3.69635,-3.568637 z' />
  <path class='st0' d='m 72.25864,84.624638 c 4.108046,3.143003 -0.737059,6.895259 -1.994918,8.323564 -3.586718,5.561143 -6.495079,-4.197379 -10.07759,-5.582178 -4.443422,-1.088878 1.349298,-7.249213 2.503526,-2.503449 2.464639,4.517161 2.304019,-3.70697 6.291113,-1.995914 1.280083,0.137865 2.410691,0.864819 3.277869,1.757977 z m -2.646109,2.323242 c -4.797162,-3.078383 -2.810517,6.305507 0.515161,1.990646 0.296432,-0.688582 0.01209,-1.493412 -0.515161,-1.990646 z' />
  <path class='st0' d='m 78.230641,79.436735 c 4.142121,3.027466 -2.020102,10.435276 -3.450543,5.477315 3.306312,-5.248112 -9.186019,-2.220094 -5.805994,-8.77679 -0.544141,-3.93011 6.797826,-2.102227 3.386015,0.245477 -0.181085,2.915838 4.637371,1.019311 5.870522,3.053982 z' />
  <path class='st0' d='m 82.744502,72.597397 c -4.901605,1.926521 1.146497,6.285555 2.559694,2.225783 6.21817,3.539297 -6.640186,8.416664 -7.590325,1.997457 -2.24365,-2.914883 4.026676,-10.148618 5.030631,-4.22324 z' />
  <path class='st0' d='m 90.727458,64.259158 c 1.583987,1.690029 3.321317,3.2696 4.81267,5.026353 -2.535706,6.849794 -6.445583,-5.918773 -8.388458,-0.167017 0.782768,2.03426 5.877405,3.752079 2.670979,5.711199 -3.315119,1.519161 -5.782422,-5.157931 -8.858893,-6.780537 -4.229842,-1.139816 1.510134,-7.074128 2.586227,-2.385939 3.141198,5.495193 1.840537,-5.598295 7.177489,-1.404062 z' />
  <path class='st0' d='m 99.622027,58.374253 c 1.493293,1.9548 -6.281936,7.024659 -0.885258,4.740447 0.386238,-4.434477 6.131941,-1.133173 2.175851,1.618005 -4.421491,6.12739 -13.666659,-3.151506 -7.058299,-7.136537 1.785129,-1.119329 4.348209,-0.743179 5.767706,0.778085 z m -2.900824,1.89746 c -3.608188,-2.208543 -2.280489,5.00803 -0.12563,0.329531 z' />
  <path class='st0' d='m 115.18023,50.570441 c -1.61703,5.201678 -4.6204,-0.364502 -7.01598,-1.749619 -4.40977,2.122562 4.89641,4.913939 1.89606,7.018157 -2.48061,3.877635 -4.11404,-4.060614 -7.01192,-2.6391 -1.76318,3.107252 7.28394,6.252304 0.87346,7.876177 -1.74515,-2.956649 -9.055498,-5.610518 -3.950378,-8.66062 1.696478,1.897023 1.770418,-5.43503 5.347308,-3.072411 -0.44014,-5.474701 6.11995,-4.950882 7.7846,-0.815355 0.69076,0.682329 1.39587,1.351469 2.07685,2.042771 z' />
  <path class='st0' d='m 120.54891,39.417125 c 2.50681,1.334124 4.80466,4.941837 0.75044,5.297362 -0.46414,1.89865 -5.25369,5.602652 -8.01742,1.815475 -3.87345,-2.809139 -0.0676,-7.603869 2.3036,-8.133924 1.6795,-3.853018 3.16703,-1.199465 4.96338,1.021087 z m -2.2464,2.175828 c -4.8049,-2.992167 -3.08987,6.380358 0.42374,2.036159 0.33052,-0.677508 0.12099,-1.525836 -0.42374,-2.036159 z' />
  <path class='st0' d='m 128.50836,24.06821 c -5.10403,3.035506 3.20535,6.383175 5.05938,9.450276 -0.91853,2.95886 -4.06493,3.650723 -5.34691,0.265618 -2.25715,-2.089033 -4.65672,-6.948595 -7.07024,-2.584686 -4.71758,-3.764394 3.81217,-5.812054 5.12382,-9.226328 0.75738,0.677487 1.38637,1.498638 2.23389,2.095175 z' />
  <path class='st0' d='m 137.14366,22.299812 c -3.09615,2.259885 0.71537,4.412454 1.99042,6.435866 -3.08975,5.080354 -5.91384,-2.98648 -8.92144,-4.094939 1.44369,-3.219573 3.3497,-1.335928 4.27156,-4.41058 0.97822,-0.894325 1.75044,1.871047 2.65946,2.069653 z' />
  <path class='st0' d='m 136.85093,14.890174 c 2.31562,5.283511 -7.17975,1.771993 -1.29675,-0.475107 l 0.7108,0.08973 z m 4.867,5.317354 c 2.56912,1.439678 4.26517,4.725219 0.30678,5.233637 -1.56592,-3.098864 -9.51683,-5.749448 -3.64502,-8.633714 1.17746,0.325095 2.15375,2.591149 3.33824,3.400077 z' />
  <path class='st0' d='m 149.95578,11.976423 c 2.50679,1.334142 4.80455,4.94192 0.75041,5.297394 -0.4641,1.898604 -5.25368,5.602645 -8.0174,1.81545 -3.87347,-2.80918 -0.0676,-7.603844 2.30366,-8.133968 1.67949,-3.8530525 3.16695,-1.1993573 4.96333,1.021124 z m -2.24641,2.175828 c -4.80489,-2.992177 -3.08986,6.380343 0.42374,2.036167 0.33055,-0.677518 0.121,-1.52585 -0.42374,-2.036167 z' />
  <path class='st0' d='m 153.26135,7.538431 c 2.60497,1.5799548 6.03999,5.944272 1.08117,6.050232 -2.53319,-3.231828 -7.20316,-6.4304525 -8.84748,-9.4582682 1.89121,-2.8664883 3.78452,-2.247699 5.38514,0.8929426 0.78017,0.8503859 1.57195,1.6911437 2.38118,2.5150667 z' />
  </pattern>  
  <linearGradient id='groupUnderTitleLine' x1='0%' y1='0%' x2='100%' y2='0%' >
          <stop offset='0%' stop-color='#999999' stop-opacity='0.7'/> 
          <stop offset='100%' stop-color='#999999' stop-opacity='0' /> 
   </linearGradient>
  <radialGradient id='calloutGradient' cx='25%' cy='20%' r='80%' fx='10%' fy='10%'>
	   <stop offset='0%' stop-color='#ffffff' />
    <stop offset='100%' stop-color='#f8f6d1' />
  </radialGradient>
  <filter id='shadow' width='120%' height='120%'> 
      <feOffset result='offOut' in='SourceGraphic' dx='1' dy='1' /> 
      <feColorMatrix result='matrixOut' in='offOut' 
      values='0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.1 0' /> 
      <feGaussianBlur result='blurOut' in='matrixOut' stdDeviation='3' /> 
      <feBlend in='SourceGraphic' in2='blurOut' /> 
    </filter> 
  <filter id='fkShadow' height='130%'> 
    <feGaussianBlur in='SourceAlpha' stdDeviation='1.5'/> <!-- stdDeviation is how much to blur -->
    <feOffset dx='1.2' dy='1.2' result='offsetblur'/> <!-- how much to offset -->
    <feMerge>
    <feMergeNode/> <!-- this contains the offset blurred image -->
    <feMergeNode in='SourceGraphic'/> <!-- this contains the element that the filter is applied to -->
    </feMerge>
  </filter>
  <radialGradient id='legendGradient' fx='5%' fy='5%' r='75%' >
          <stop offset='0%' stop-color='#eefbf2' stop-opacity='1'/> 
          <stop offset='100%' stop-color='#cff9cb' stop-opacity='1' /> 
   </radialGradient>
  <symbol id='calloutArrowDown' >
      <path d='M 0,0 L 8,12 L 16,0 z' style='fill:#f8f6d1;stroke:none; filter: url(#shadow);' />
      <path d='M 0,0 L 8,12 L 16,0' style='stroke:#bebdbd; stroke-width:0.5;' />
  </symbol>
  <symbol id='calloutArrowUp' >
      <path d='M 0,16 L 8,4 L 16,16 z' style='fill:#ffffff; stroke:none; filter: url(#shadow);' />
      <path d='M 0,16 L 8,4 L 16,16' style='stroke:#bebdbd; stroke-width:0.5;' />
  </symbol>
  <symbol id='pk' >
    <g transform='scale(0.99)'>
     <path style='fill:#fffa7d;stroke:#765f03;stroke-width:0.6;stroke-linecap:round;stroke-linejoin:round;'
        d='M 9.3678877,3.5695485 C 9.1030218,3.2729386 9.0796382,2.7628519 9.3396185,2.4517097 9.5449651,2.1956495 9.9040386,2.0980533 10.199638,2.2169415 10.533525,2.3415459 10.775153,2.706942 10.750675,3.0842709 10.737029,3.3980003 10.541153,3.699122 10.258248,3.8066067 9.966649,3.9250429 9.6169668,3.8418805 9.4008073,3.6062324 9.3894892,3.5943518 9.3785264,3.582104 9.3678886,3.5695487 z M 11.226617,6.9916004 C 11.888137,6.3548946 12.293488,5.4172188 12.311087,4.442353 12.378144,2.7379364 11.248678,1.0541269 9.7322318,0.44767357 8.3887112,-0.1280313 6.7865012,0.26822889 5.8918395,1.4007929 5.080823,2.3839145 4.9336815,3.8452096 5.3635544,5.101615 L 4.3670905,5.315913 C 4.0664984,5.3682645 4.0967703,5.6316724 4.2574957,5.8208829 L 4.9124,6.5655244 4.1543436,7.2512357 3.2136002,7.2163506 3.1674775,8.5586827 2.0406832,8.5086512 1.5965306,8.9299953 1.5471661,10.179833 0.75616674,10.195223 0.2112857,10.758575 0.15354288,11.735988 0.07199052,12.765553 c 0.36440953,0.238225 0.79006967,0.195492 1.44938278,-0.02675 L 6.3033562,8.1282037 6.8217102,8.6765688 C 6.9985465,8.8799427 7.3003699,8.7497574 7.358381,8.5016252 L 7.4938877,7.5084164 c 0.8537488,0.3985387 1.8303125,0.4711541 2.6851793,0.1427713 0.393927,-0.1407258 0.746858,-0.3701772 1.04755,-0.6595873 z'/>
     <path d='M 6.8014948,6.3102123 0.15369063,13.024481 0.21560535,12.141962 6.0062342,6.2683782 z'
        style='fill:#ffe5a5;fill-opacity:1;stroke:#854e31;stroke-width:0.06912433;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:3.00300009'/>
    </g>
  </symbol>
  <symbol id='dist' >
    <g transform='scale(0.99)'>
      <path style='fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;' d='M 0.177,11.431 12.28,11.449'/>
      <path style='fill:none;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;' d='m 6.124,3.954 0.066,7.154 v 0'/>
      <rect width='11.78' height='3.40' x='0.40' y='0.44' style='fill:#fffa7d;stroke:#765f03;stroke-width:0.6;' ry='0.83'/>
      <rect width='11.78' height='3.40' x='0.40' y='5.609' style='fill:#fffa7d;stroke:#765f03;stroke-width:0.6;' ry='0.832'/>
    </g>
  </symbol>
  <symbol id='unq' >
    <g transform='scale(0.99)'>
      <rect style='fill:#fbea8e;stroke:#7e4d31;stroke-width:0.71934468;stroke-linecap:round;stroke-linejoin:round;'
         width='2.29' height='8.43' x='7.48' y='-0.76' ry='1.14' transform='matrix(0.701,0.713,-0.727,0.685,0,0)' />
      <path style='fill:white;stroke:#858585;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;'
         d='m 26.04,8.64 a 4.13,4.13 0 1 1 -8.26,0 4.13,4.13 0 1 1 8.26,0 z'
         transform='matrix(1.025,0,0,0.987,-14.690,-3.862)' />
      <text x='5.8' y='7.4' style='font-size:7px;fill:#8a8a8a;'>1</text>
    </g>
  </symbol>
  <symbol id='idx' >
    <g transform='scale(0.99)'>
      <rect style='fill:#fbea8e;stroke:#7e4d31;stroke-width:0.71934468;stroke-linecap:round;stroke-linejoin:round;'
         width='2.29' height='8.43' x='7.48' y='-0.76' ry='1.14' transform='matrix(0.701,0.713,-0.727,0.685,0,0)' />
      <path style='fill:white;stroke:#858585;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;'
         d='m 26.04,8.64 a 4.13,4.13 0 1 1 -8.26,0 4.13,4.13 0 1 1 8.26,0 z'
         transform='matrix(1.025,0,0,0.987,-14.690,-3.862)' />
    </g>
  </symbol>
  <symbol id='fk' >
    <g transform='scale(0.87)'>
      <path style='fill:#f3e1b7;stroke:#7e471f;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
      d='M 12.48,0.33 7.07,0.89 9.067,2.974 0.329,11.731 1.073,12.597 9.811,3.841 11.77,5.78 z' />
    </g>
  </symbol>
  <symbol id='ref' >
    <g transform='scale(0.87)'>
      <path style='fill:#f3e1b7;stroke:#7e471f;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
          d='M 0.10,12.70 5.31,12.15 3.40,10.06 11.82,1.32 11.11,0.45 2.68,9.19 0.80,7.24 z'/>
    </g>
  </symbol>
  <symbol id='flag0' >
    <g transform='scale(0.92)'>
      <path style='fill:#b7d0f6;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
          d='M 0.12,12.67 0.16,7.22 C 2.59,7.22 4.13,8.78 9.22,4.22 5.68,4.98 2.53,4.50 0.09,1.80 z'/>
    </g>
  </symbol>
  <symbol id='flag1' >
    <g transform='scale(0.92)'>
      <path style='fill:#f4a393;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
          d='M 0.12,12.67 0.16,7.22 C 2.59,7.22 4.13,8.78 9.22,4.22 5.68,4.98 2.53,4.50 0.09,1.80 z'/>
    </g>
  </symbol>
  <symbol id='flag2' >
    <g transform='scale(0.92)'>
      <path style='fill:#77ec8b;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
          d='M 0.12,12.67 0.16,7.22 C 2.59,7.22 4.13,8.78 9.22,4.22 5.68,4.98 2.53,4.50 0.09,1.80 z'/>
    </g>
  </symbol>
  <symbol id='nn' >
  <path style='stroke:#9b3e50;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;'
          d='M 0,0 3,3 M 0,3 3,0 z'/>
  </symbol>
  <symbol id='view' >
    <g transform='scale(0.99)'>
     <line x1='12' y1='6' x2='19' y2='0' stroke='black' stroke-width='0.5' />
     <line x1='0' y1='6' x2='7' y2='0' stroke='black' stroke-width='0.5' />
     <circle cx='3' cy='6' r='3' fill='#f9ebbc' stroke='black' stroke-width='0.5'/>
     <circle cx='10' cy='6' r='3' fill='#f9ebbc' stroke='black' stroke-width='0.5'/>
    </g>
  </symbol>
  <marker id='arrow01' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 0.00,4.00 L 16.00,4.00 z' />
  </marker>
  <marker id='arrow1' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 0.00,4.00 L 16.00,4.00 z' />
  </marker>
  <marker id='foot01' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 1.60,4.00 L 3.20,4.00 L 4.80,4.00 L 6.40,4.00 z' />
  </marker>
  <marker id='foot0p' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 1.60,4.00 L 3.20,4.00 L 4.80,4.00 L 6.40,4.00 z' />
    <path d='M 0.00,0.00 L 8.00,4.00 L 0.00,8.00' />
  </marker>
  <marker id='foot1' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 0.00,4.00 L 16.00,4.00 z' />
  </marker>
  <marker id='foot1p' viewBox='0 0 16.00 8.00' refX='8.00' refY='4.00' markerWidth='16.00' markerHeight='8.00' orient='auto'>
    <path d='M 0.00,4.00 L 16.00,4.00 z' />
    <path d='M 0.00,0.00 L 8.00,4.00 L 0.00,8.00' />
  </marker>
  <linearGradient id='tbg_3986C1' x1='0%' y1='0%' x2='0%' y2='100%' >
     <stop offset='0%' stop-color='#E0EDF8' /> 
     <stop offset='60%' stop-color='#C1DAEE' /> 
     <stop offset='100%' stop-color='#E0EDF8' /> 
  </linearGradient>
</defs>

<!-- == Desktop == -->
<rect x='1' y='1' width='1374' height='1244' rx='8' ry='8' style='fill:url(#layoutBgB); stroke:#777777; stroke-width:0.5;' />

<!-- == Legend == -->
<g transform='translate(10,10)'>
  <rect x='10' y='10' width='330' height='56' rx='6' ry='6' style='fill:url(#legendGradient);filter:url(#shadow);'/> 
  <text x='20' y='25'>系统管理模块表结构</text> 
  <text x='20' y='39' style='fill:#aaaaaa; font-size:11px;'><tspan>Move the mouse over tables &amp; columns to read the comments.</tspan></text> 
  <a xlink:href='https://www.dbschema.com'><text x='20' y='53' style='fill:#486dc1; font-size:12px;'><tspan>Generated using DbSchema © Wise Coders</tspan></text></a> 
</g>

<g transform='translate(0,110)'>
<!-- == Group '系统模块数表结构' == -->
<rect class='grp' style='fill:#C4E0F9;stroke:#CED7E0' x='32' y='45' width='1312' height='1026' />
<text x='44' y='61'>系统模块数表结构</text>
<rect style='fill:url(#groupUnderTitleLine); stroke-width:2;' x='44' y='65' width='1288' height='2' />

<!-- == Table 'sys_user' == -->
<rect class='entity' style='stroke:#1E5D8F' x='48' y='72' width='128' height='384' rx='8' ry='8' />
<path d='M 48 100 L 48 80 Q 48 72 56 72 L 168 72 Q 176 72 176 80 L 176 100 L48 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='48' y='72' width='128' height='384' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_user'><text x='83' y='92' >sys_user</text><title>Table ry.sys_user
用户表</title></a>
  <use id='nn' x='50' y='109' xlink:href='#nn'/><use id='pk' x='50' y='108' xlink:href='#pk'><title>Pk pk_sys_user ( user_id ) </title></use><a xlink:href='#ry.sys_user_user_id'><text id='ry.sys_user.user_id' x='67' y='119'>user_id</text><title>user_id
* int
用户ID</title></a>
<text x='173' y='116' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_user_parent_user_id'><text id='ry.sys_user.parent_user_id' x='67' y='135'>parent_user_id</text><title>parent_user_id
int
用户父ID</title></a>
<text x='173' y='132' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_user_dept_id'><text id='ry.sys_user.dept_id' x='67' y='151'>dept_id</text><title>dept_id
int
部门ID</title></a>
<text x='173' y='148' text-anchor='end' class='colType'>#</text>  <use id='nn' x='50' y='157' xlink:href='#nn'/><a xlink:href='#ry.sys_user_login_name'><text id='ry.sys_user.login_name' x='67' y='167'>login_name</text><title>login_name
* varchar(30)
登录账号</title></a>
<text x='173' y='164' text-anchor='end' class='colType'>t</text>  <use id='nn' x='50' y='173' xlink:href='#nn'/><a xlink:href='#ry.sys_user_user_name'><text id='ry.sys_user.user_name' x='67' y='183'>user_name</text><title>user_name
* varchar(30)
用户昵称</title></a>
<text x='173' y='180' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_user_type'><text id='ry.sys_user.user_type' x='67' y='199'>user_type</text><title>user_type
varchar(2) default '00'
用户类型（00系统用户）</title></a>
<text x='173' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_email'><text id='ry.sys_user.email' x='67' y='215'>email</text><title>email
varchar(50) default ''
用户邮箱</title></a>
<text x='173' y='212' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_phonenumber'><text id='ry.sys_user.phonenumber' x='67' y='231'>phonenumber</text><title>phonenumber
varchar(11) default ''
手机号码</title></a>
<text x='173' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_sex'><text id='ry.sys_user.sex' x='67' y='247'>sex</text><title>sex
char(1) default '0'
用户性别（0男 1女 2未知）</title></a>
<text x='173' y='244' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_user_avatar'><text id='ry.sys_user.avatar' x='67' y='263'>avatar</text><title>avatar
varchar(100) default ''
头像路径</title></a>
<text x='173' y='260' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_password'><text id='ry.sys_user.password' x='67' y='279'>password</text><title>password
varchar(50) default ''
密码</title></a>
<text x='173' y='276' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_salt'><text id='ry.sys_user.salt' x='67' y='295'>salt</text><title>salt
varchar(20) default ''
盐加密</title></a>
<text x='173' y='292' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_status'><text id='ry.sys_user.status' x='67' y='311'>status</text><title>status
char(1) default '0'
帐号状态（0正常 1停用）</title></a>
<text x='173' y='308' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_user_del_flag'><text id='ry.sys_user.del_flag' x='67' y='327'>del_flag</text><title>del_flag
char(1) default '0'
删除标志（0代表存在 2代表删除）</title></a>
<text x='173' y='324' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_user_login_ip'><text id='ry.sys_user.login_ip' x='67' y='343'>login_ip</text><title>login_ip
varchar(50) default ''
最后登陆IP</title></a>
<text x='173' y='340' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_login_date'><text id='ry.sys_user.login_date' x='67' y='359'>login_date</text><title>login_date
datetime
最后登陆时间</title></a>
<text x='173' y='356' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_user_create_by'><text id='ry.sys_user.create_by' x='67' y='375'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='173' y='372' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_create_time'><text id='ry.sys_user.create_time' x='67' y='391'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='173' y='388' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_user_update_by'><text id='ry.sys_user.update_by' x='67' y='407'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='173' y='404' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_update_time'><text id='ry.sys_user.update_time' x='67' y='423'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='173' y='420' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_user_remark'><text id='ry.sys_user.remark' x='67' y='439'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='173' y='436' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_dept' == -->
<rect class='entity' style='stroke:#1E5D8F' x='208' y='72' width='112' height='272' rx='8' ry='8' />
<path d='M 208 100 L 208 80 Q 208 72 216 72 L 312 72 Q 320 72 320 80 L 320 100 L208 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='208' y='72' width='112' height='272' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_dept'><text x='234' y='92' >sys_dept</text><title>Table ry.sys_dept
部门表</title></a>
  <use id='nn' x='210' y='109' xlink:href='#nn'/><use id='pk' x='210' y='108' xlink:href='#pk'><title>Pk pk_sys_dept ( dept_id ) </title></use><a xlink:href='#ry.sys_dept_dept_id'><text id='ry.sys_dept.dept_id' x='227' y='119'>dept_id</text><title>dept_id
* int
部门id</title></a>
<text x='317' y='116' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dept_parent_id'><text id='ry.sys_dept.parent_id' x='227' y='135'>parent_id</text><title>parent_id
int default 0
父部门id</title></a>
<text x='317' y='132' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dept_ancestors'><text id='ry.sys_dept.ancestors' x='227' y='151'>ancestors</text><title>ancestors
varchar(50) default ''
祖级列表</title></a>
<text x='317' y='148' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_dept_name'><text id='ry.sys_dept.dept_name' x='227' y='167'>dept_name</text><title>dept_name
varchar(30) default ''
部门名称</title></a>
<text x='317' y='164' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_order_num'><text id='ry.sys_dept.order_num' x='227' y='183'>order_num</text><title>order_num
int default 0
显示顺序</title></a>
<text x='317' y='180' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dept_leader'><text id='ry.sys_dept.leader' x='227' y='199'>leader</text><title>leader
varchar(20)
负责人</title></a>
<text x='317' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_phone'><text id='ry.sys_dept.phone' x='227' y='215'>phone</text><title>phone
varchar(11)
联系电话</title></a>
<text x='317' y='212' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_email'><text id='ry.sys_dept.email' x='227' y='231'>email</text><title>email
varchar(50)
邮箱</title></a>
<text x='317' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_status'><text id='ry.sys_dept.status' x='227' y='247'>status</text><title>status
char(1) default '0'
部门状态（0正常 1停用）</title></a>
<text x='317' y='244' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_dept_del_flag'><text id='ry.sys_dept.del_flag' x='227' y='263'>del_flag</text><title>del_flag
char(1) default '0'
删除标志（0代表存在 2代表删除）</title></a>
<text x='317' y='260' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_dept_create_by'><text id='ry.sys_dept.create_by' x='227' y='279'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='317' y='276' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_create_time'><text id='ry.sys_dept.create_time' x='227' y='295'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='317' y='292' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_dept_update_by'><text id='ry.sys_dept.update_by' x='227' y='311'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='317' y='308' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dept_update_time'><text id='ry.sys_dept.update_time' x='227' y='327'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='317' y='324' text-anchor='end' class='colType'>d</text>
<!-- == Table 'sys_role' == -->
<rect class='entity' style='stroke:#1E5D8F' x='352' y='72' width='112' height='240' rx='8' ry='8' />
<path d='M 352 100 L 352 80 Q 352 72 360 72 L 456 72 Q 464 72 464 80 L 464 100 L352 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='352' y='72' width='112' height='240' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_role'><text x='381' y='92' >sys_role</text><title>Table ry.sys_role
角色表</title></a>
  <use id='nn' x='354' y='109' xlink:href='#nn'/><use id='pk' x='354' y='108' xlink:href='#pk'><title>Pk pk_sys_role ( role_id ) </title></use><a xlink:href='#ry.sys_role_role_id'><text id='ry.sys_role.role_id' x='371' y='119'>role_id</text><title>role_id
* int
角色ID</title></a>
<text x='461' y='116' text-anchor='end' class='colType'>#</text>  <use id='nn' x='354' y='125' xlink:href='#nn'/><a xlink:href='#ry.sys_role_role_name'><text id='ry.sys_role.role_name' x='371' y='135'>role_name</text><title>role_name
* varchar(30)
角色名称</title></a>
<text x='461' y='132' text-anchor='end' class='colType'>t</text>  <use id='nn' x='354' y='141' xlink:href='#nn'/><a xlink:href='#ry.sys_role_role_key'><text id='ry.sys_role.role_key' x='371' y='151'>role_key</text><title>role_key
* varchar(100)
角色权限字符串</title></a>
<text x='461' y='148' text-anchor='end' class='colType'>t</text>  <use id='nn' x='354' y='157' xlink:href='#nn'/><a xlink:href='#ry.sys_role_role_sort'><text id='ry.sys_role.role_sort' x='371' y='167'>role_sort</text><title>role_sort
* int
显示顺序</title></a>
<text x='461' y='164' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_role_data_scope'><text id='ry.sys_role.data_scope' x='371' y='183'>data_scope</text><title>data_scope
char(1) default '1'
数据范围（1：全部数据权限 2：自定数据权限）</title></a>
<text x='461' y='180' text-anchor='end' class='colType'>c</text>  <use id='nn' x='354' y='189' xlink:href='#nn'/><a xlink:href='#ry.sys_role_status'><text id='ry.sys_role.status' x='371' y='199'>status</text><title>status
* char(1)
角色状态（0正常 1停用）</title></a>
<text x='461' y='196' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_role_del_flag'><text id='ry.sys_role.del_flag' x='371' y='215'>del_flag</text><title>del_flag
char(1) default '0'
删除标志（0代表存在 2代表删除）</title></a>
<text x='461' y='212' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_role_create_by'><text id='ry.sys_role.create_by' x='371' y='231'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='461' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_role_create_time'><text id='ry.sys_role.create_time' x='371' y='247'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='461' y='244' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_role_update_by'><text id='ry.sys_role.update_by' x='371' y='263'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='461' y='260' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_role_update_time'><text id='ry.sys_role.update_time' x='371' y='279'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='461' y='276' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_role_remark'><text id='ry.sys_role.remark' x='371' y='295'>remark</text><title>remark
varchar(500)
备注</title></a>
<text x='461' y='292' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_post' == -->
<rect class='entity' style='stroke:#1E5D8F' x='480' y='72' width='112' height='208' rx='8' ry='8' />
<path d='M 480 100 L 480 80 Q 480 72 488 72 L 584 72 Q 592 72 592 80 L 592 100 L480 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='480' y='72' width='112' height='208' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_post'><text x='507' y='92' >sys_post</text><title>Table ry.sys_post
岗位表</title></a>
  <use id='nn' x='482' y='109' xlink:href='#nn'/><use id='pk' x='482' y='108' xlink:href='#pk'><title>Pk pk_sys_post ( post_id ) </title></use><a xlink:href='#ry.sys_post_post_id'><text id='ry.sys_post.post_id' x='499' y='119'>post_id</text><title>post_id
* int
岗位ID</title></a>
<text x='589' y='116' text-anchor='end' class='colType'>#</text>  <use id='nn' x='482' y='125' xlink:href='#nn'/><a xlink:href='#ry.sys_post_post_code'><text id='ry.sys_post.post_code' x='499' y='135'>post_code</text><title>post_code
* varchar(64)
岗位编码</title></a>
<text x='589' y='132' text-anchor='end' class='colType'>t</text>  <use id='nn' x='482' y='141' xlink:href='#nn'/><a xlink:href='#ry.sys_post_post_name'><text id='ry.sys_post.post_name' x='499' y='151'>post_name</text><title>post_name
* varchar(50)
岗位名称</title></a>
<text x='589' y='148' text-anchor='end' class='colType'>t</text>  <use id='nn' x='482' y='157' xlink:href='#nn'/><a xlink:href='#ry.sys_post_post_sort'><text id='ry.sys_post.post_sort' x='499' y='167'>post_sort</text><title>post_sort
* int
显示顺序</title></a>
<text x='589' y='164' text-anchor='end' class='colType'>#</text>  <use id='nn' x='482' y='173' xlink:href='#nn'/><a xlink:href='#ry.sys_post_status'><text id='ry.sys_post.status' x='499' y='183'>status</text><title>status
* char(1)
状态（0正常 1停用）</title></a>
<text x='589' y='180' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_post_create_by'><text id='ry.sys_post.create_by' x='499' y='199'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='589' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_post_create_time'><text id='ry.sys_post.create_time' x='499' y='215'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='589' y='212' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_post_update_by'><text id='ry.sys_post.update_by' x='499' y='231'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='589' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_post_update_time'><text id='ry.sys_post.update_time' x='499' y='247'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='589' y='244' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_post_remark'><text id='ry.sys_post.remark' x='499' y='263'>remark</text><title>remark
varchar(500)
备注</title></a>
<text x='589' y='260' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_menu' == -->
<rect class='entity' style='stroke:#1E5D8F' x='624' y='72' width='112' height='272' rx='8' ry='8' />
<path d='M 624 100 L 624 80 Q 624 72 632 72 L 728 72 Q 736 72 736 80 L 736 100 L624 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='624' y='72' width='112' height='272' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_menu'><text x='647' y='92' >sys_menu</text><title>Table ry.sys_menu
菜单表</title></a>
  <use id='nn' x='626' y='109' xlink:href='#nn'/><use id='pk' x='626' y='108' xlink:href='#pk'><title>Pk pk_sys_menu ( menu_id ) </title></use><a xlink:href='#ry.sys_menu_menu_id'><text id='ry.sys_menu.menu_id' x='643' y='119'>menu_id</text><title>menu_id
* int
菜单ID</title></a>
<text x='733' y='116' text-anchor='end' class='colType'>#</text>  <use id='nn' x='626' y='125' xlink:href='#nn'/><a xlink:href='#ry.sys_menu_menu_name'><text id='ry.sys_menu.menu_name' x='643' y='135'>menu_name</text><title>menu_name
* varchar(50)
菜单名称</title></a>
<text x='733' y='132' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_parent_id'><text id='ry.sys_menu.parent_id' x='643' y='151'>parent_id</text><title>parent_id
int default 0
父菜单ID</title></a>
<text x='733' y='148' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_menu_order_num'><text id='ry.sys_menu.order_num' x='643' y='167'>order_num</text><title>order_num
int default 0
显示顺序</title></a>
<text x='733' y='164' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_menu_url'><text id='ry.sys_menu.url' x='643' y='183'>url</text><title>url
varchar(200) default '#'
请求地址</title></a>
<text x='733' y='180' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_menu_type'><text id='ry.sys_menu.menu_type' x='643' y='199'>menu_type</text><title>menu_type
char(1) default ''
菜单类型（M目录 C菜单 F按钮）</title></a>
<text x='733' y='196' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_menu_visible'><text id='ry.sys_menu.visible' x='643' y='215'>visible</text><title>visible
char(1) default '0'
菜单状态（0显示 1隐藏）</title></a>
<text x='733' y='212' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_menu_perms'><text id='ry.sys_menu.perms' x='643' y='231'>perms</text><title>perms
varchar(100)
权限标识</title></a>
<text x='733' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_icon'><text id='ry.sys_menu.icon' x='643' y='247'>icon</text><title>icon
varchar(100) default '#'
菜单图标</title></a>
<text x='733' y='244' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_create_by'><text id='ry.sys_menu.create_by' x='643' y='263'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='733' y='260' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_create_time'><text id='ry.sys_menu.create_time' x='643' y='279'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='733' y='276' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_menu_update_by'><text id='ry.sys_menu.update_by' x='643' y='295'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='733' y='292' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_menu_update_time'><text id='ry.sys_menu.update_time' x='643' y='311'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='733' y='308' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_menu_remark'><text id='ry.sys_menu.remark' x='643' y='327'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='733' y='324' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_config' == -->
<rect class='entity' style='stroke:#1E5D8F' x='784' y='72' width='112' height='208' rx='8' ry='8' />
<path d='M 784 100 L 784 80 Q 784 72 792 72 L 888 72 Q 896 72 896 80 L 896 100 L784 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='784' y='72' width='112' height='208' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_config'><text x='805' y='92' >sys_config</text><title>Table ry.sys_config
系统设置</title></a>
  <use id='nn' x='786' y='109' xlink:href='#nn'/><use id='pk' x='786' y='108' xlink:href='#pk'><title>Pk pk_sys_config ( config_id ) </title></use><a xlink:href='#ry.sys_config_config_id'><text id='ry.sys_config.config_id' x='803' y='119'>config_id</text><title>config_id
* int
参数主键</title></a>
<text x='893' y='116' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_config_config_name'><text id='ry.sys_config.config_name' x='803' y='135'>config_name</text><title>config_name
varchar(100) default ''
参数名称</title></a>
<text x='893' y='132' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_config_config_key'><text id='ry.sys_config.config_key' x='803' y='151'>config_key</text><title>config_key
varchar(100) default ''
参数键名</title></a>
<text x='893' y='148' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_config_config_value'><text id='ry.sys_config.config_value' x='803' y='167'>config_value</text><title>config_value
varchar(100) default ''
参数键值</title></a>
<text x='893' y='164' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_config_config_type'><text id='ry.sys_config.config_type' x='803' y='183'>config_type</text><title>config_type
char(1) default 'N'
系统内置（Y是 N否）</title></a>
<text x='893' y='180' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_config_create_by'><text id='ry.sys_config.create_by' x='803' y='199'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='893' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_config_create_time'><text id='ry.sys_config.create_time' x='803' y='215'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='893' y='212' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_config_update_by'><text id='ry.sys_config.update_by' x='803' y='231'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='893' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_config_update_time'><text id='ry.sys_config.update_time' x='803' y='247'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='893' y='244' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_config_remark'><text id='ry.sys_config.remark' x='803' y='263'>remark</text><title>remark
varchar(500)
备注</title></a>
<text x='893' y='260' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_dict_data' == -->
<rect class='entity' style='stroke:#1E5D8F' x='928' y='72' width='112' height='288' rx='8' ry='8' />
<path d='M 928 100 L 928 80 Q 928 72 936 72 L 1032 72 Q 1040 72 1040 80 L 1040 100 L928 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='928' y='72' width='112' height='288' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_dict_data'><text x='941' y='92' >sys_dict_data</text><title>Table ry.sys_dict_data
数据字典</title></a>
  <use id='nn' x='930' y='109' xlink:href='#nn'/><use id='pk' x='930' y='108' xlink:href='#pk'><title>Pk pk_sys_dict_data ( dict_code ) </title></use><a xlink:href='#ry.sys_dict_data_dict_code'><text id='ry.sys_dict_data.dict_code' x='947' y='119'>dict_code</text><title>dict_code
* int
字典编码</title></a>
<text x='1037' y='116' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dict_data_dict_sort'><text id='ry.sys_dict_data.dict_sort' x='947' y='135'>dict_sort</text><title>dict_sort
int default 0
字典排序</title></a>
<text x='1037' y='132' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dict_data_dict_label'><text id='ry.sys_dict_data.dict_label' x='947' y='151'>dict_label</text><title>dict_label
varchar(100) default ''
字典标签</title></a>
<text x='1037' y='148' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_dict_value'><text id='ry.sys_dict_data.dict_value' x='947' y='167'>dict_value</text><title>dict_value
varchar(100) default ''
字典键值</title></a>
<text x='1037' y='164' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_dict_type'><text id='ry.sys_dict_data.dict_type' x='947' y='183'>dict_type</text><title>dict_type
varchar(100) default ''
字典类型</title></a>
<text x='1037' y='180' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_dict_link'><text id='ry.sys_dict_data.dict_link' x='947' y='199'>dict_link</text><title>dict_link
varchar(255)
连接地址</title></a>
<text x='1037' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_css_class'><text id='ry.sys_dict_data.css_class' x='947' y='215'>css_class</text><title>css_class
varchar(100)
样式属性（其他样式扩展）</title></a>
<text x='1037' y='212' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_list_class'><text id='ry.sys_dict_data.list_class' x='947' y='231'>list_class</text><title>list_class
varchar(100)
表格回显样式</title></a>
<text x='1037' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_is_default'><text id='ry.sys_dict_data.is_default' x='947' y='247'>is_default</text><title>is_default
char(1) default 'N'
是否默认（Y是 N否）</title></a>
<text x='1037' y='244' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_dict_data_status'><text id='ry.sys_dict_data.status' x='947' y='263'>status</text><title>status
char(1) default '0'
状态（0正常 1停用）</title></a>
<text x='1037' y='260' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_dict_data_create_by'><text id='ry.sys_dict_data.create_by' x='947' y='279'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='1037' y='276' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_create_time'><text id='ry.sys_dict_data.create_time' x='947' y='295'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1037' y='292' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_dict_data_update_by'><text id='ry.sys_dict_data.update_by' x='947' y='311'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='1037' y='308' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_data_update_time'><text id='ry.sys_dict_data.update_time' x='947' y='327'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='1037' y='324' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_dict_data_remark'><text id='ry.sys_dict_data.remark' x='947' y='343'>remark</text><title>remark
varchar(500)
备注</title></a>
<text x='1037' y='340' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_dict_type' == -->
<rect class='entity' style='stroke:#1E5D8F' x='1072' y='72' width='112' height='192' rx='8' ry='8' />
<path d='M 1072 100 L 1072 80 Q 1072 72 1080 72 L 1176 72 Q 1184 72 1184 80 L 1184 100 L1072 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='1072' y='72' width='112' height='192' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_dict_type'><text x='1085' y='92' >sys_dict_type</text><title>Table ry.sys_dict_type
数据字典类型</title></a>
  <use id='nn' x='1074' y='109' xlink:href='#nn'/><use id='pk' x='1074' y='108' xlink:href='#pk'><title>Pk pk_sys_dict_type ( dict_id ) </title></use><a xlink:href='#ry.sys_dict_type_dict_id'><text id='ry.sys_dict_type.dict_id' x='1091' y='119'>dict_id</text><title>dict_id
* int
字典主键</title></a>
<text x='1181' y='116' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_dict_type_dict_name'><text id='ry.sys_dict_type.dict_name' x='1091' y='135'>dict_name</text><title>dict_name
varchar(100) default ''
字典名称</title></a>
<text x='1181' y='132' text-anchor='end' class='colType'>t</text>  <use id='unq' x='1074' y='140' xlink:href='#unq'><title>Unq dict_type ( dict_type ) </title></use><a xlink:href='#ry.sys_dict_type_dict_type'><text id='ry.sys_dict_type.dict_type' x='1091' y='151'>dict_type</text><title>dict_type
varchar(100) default ''
字典类型</title></a>
<text x='1181' y='148' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_type_status'><text id='ry.sys_dict_type.status' x='1091' y='167'>status</text><title>status
char(1) default '0'
状态（0正常 1停用）</title></a>
<text x='1181' y='164' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_dict_type_create_by'><text id='ry.sys_dict_type.create_by' x='1091' y='183'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='1181' y='180' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_type_create_time'><text id='ry.sys_dict_type.create_time' x='1091' y='199'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1181' y='196' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_dict_type_update_by'><text id='ry.sys_dict_type.update_by' x='1091' y='215'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='1181' y='212' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_dict_type_update_time'><text id='ry.sys_dict_type.update_time' x='1091' y='231'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='1181' y='228' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_dict_type_remark'><text id='ry.sys_dict_type.remark' x='1091' y='247'>remark</text><title>remark
varchar(500)
备注</title></a>
<text x='1181' y='244' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_notice' == -->
<rect class='entity' style='stroke:#1E5D8F' x='1200' y='72' width='128' height='208' rx='8' ry='8' />
<path d='M 1200 100 L 1200 80 Q 1200 72 1208 72 L 1320 72 Q 1328 72 1328 80 L 1328 100 L1200 100 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='1200' y='72' width='128' height='208' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_notice'><text x='1230' y='92' >sys_notice</text><title>Table ry.sys_notice
系统公告</title></a>
  <use id='nn' x='1202' y='109' xlink:href='#nn'/><use id='pk' x='1202' y='108' xlink:href='#pk'><title>Pk pk_sys_notice ( notice_id ) </title></use><a xlink:href='#ry.sys_notice_notice_id'><text id='ry.sys_notice.notice_id' x='1219' y='119'>notice_id</text><title>notice_id
* int
公告ID</title></a>
<text x='1325' y='116' text-anchor='end' class='colType'>#</text>  <use id='nn' x='1202' y='125' xlink:href='#nn'/><a xlink:href='#ry.sys_notice_notice_title'><text id='ry.sys_notice.notice_title' x='1219' y='135'>notice_title</text><title>notice_title
* varchar(50)
公告标题</title></a>
<text x='1325' y='132' text-anchor='end' class='colType'>t</text>  <use id='nn' x='1202' y='141' xlink:href='#nn'/><a xlink:href='#ry.sys_notice_notice_type'><text id='ry.sys_notice.notice_type' x='1219' y='151'>notice_type</text><title>notice_type
* char(1)
公告类型（1通知 2公告）</title></a>
<text x='1325' y='148' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_notice_notice_content'><text id='ry.sys_notice.notice_content' x='1219' y='167'>notice_content</text><title>notice_content
varchar(2000)
公告内容</title></a>
<text x='1325' y='164' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_notice_status'><text id='ry.sys_notice.status' x='1219' y='183'>status</text><title>status
char(1) default '0'
公告状态（0正常 1关闭）</title></a>
<text x='1325' y='180' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_notice_create_by'><text id='ry.sys_notice.create_by' x='1219' y='199'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='1325' y='196' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_notice_create_time'><text id='ry.sys_notice.create_time' x='1219' y='215'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1325' y='212' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_notice_update_by'><text id='ry.sys_notice.update_by' x='1219' y='231'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='1325' y='228' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_notice_update_time'><text id='ry.sys_notice.update_time' x='1219' y='247'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='1325' y='244' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_notice_remark'><text id='ry.sys_notice.remark' x='1219' y='263'>remark</text><title>remark
varchar(255)
备注</title></a>
<text x='1325' y='260' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_user_post' == -->
<rect class='entity' style='stroke:#1E5D8F' x='192' y='344' width='96' height='80' rx='8' ry='8' />
<path d='M 192 372 L 192 352 Q 192 344 200 344 L 280 344 Q 288 344 288 352 L 288 372 L192 372 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='192' y='344' width='96' height='80' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_user_post'><text x='195' y='364' >sys_user_post</text><title>Table ry.sys_user_post
用户岗位关联表</title></a>
  <use id='nn' x='194' y='381' xlink:href='#nn'/><use id='pk' x='194' y='380' xlink:href='#pk'><title>Pk pk_sys_user_post ( user_id, post_id ) </title></use><a xlink:href='#ry.sys_user_post_user_id'><text id='ry.sys_user_post.user_id' x='211' y='391'>user_id</text><title>user_id
* int
用户ID</title></a>
<text x='285' y='388' text-anchor='end' class='colType'>#</text>  <use id='nn' x='194' y='397' xlink:href='#nn'/><use id='pk' x='194' y='396' xlink:href='#pk'><title>Pk pk_sys_user_post ( user_id, post_id ) </title></use><a xlink:href='#ry.sys_user_post_post_id'><text id='ry.sys_user_post.post_id' x='211' y='407'>post_id</text><title>post_id
* int
岗位ID</title></a>
<text x='285' y='404' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_role_dept' == -->
<rect class='entity' style='stroke:#1E5D8F' x='304' y='344' width='96' height='80' rx='8' ry='8' />
<path d='M 304 372 L 304 352 Q 304 344 312 344 L 392 344 Q 400 344 400 352 L 400 372 L304 372 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='304' y='344' width='96' height='80' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_role_dept'><text x='308' y='364' >sys_role_dept</text><title>Table ry.sys_role_dept
角色部门关联表</title></a>
  <use id='nn' x='306' y='381' xlink:href='#nn'/><use id='pk' x='306' y='380' xlink:href='#pk'><title>Pk pk_sys_role_dept ( role_id, dept_id ) </title></use><a xlink:href='#ry.sys_role_dept_role_id'><text id='ry.sys_role_dept.role_id' x='323' y='391'>role_id</text><title>role_id
* int
角色ID</title></a>
<text x='397' y='388' text-anchor='end' class='colType'>#</text>  <use id='nn' x='306' y='397' xlink:href='#nn'/><use id='pk' x='306' y='396' xlink:href='#pk'><title>Pk pk_sys_role_dept ( role_id, dept_id ) </title></use><a xlink:href='#ry.sys_role_dept_dept_id'><text id='ry.sys_role_dept.dept_id' x='323' y='407'>dept_id</text><title>dept_id
* int
部门ID</title></a>
<text x='397' y='404' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_role_menu' == -->
<rect class='entity' style='stroke:#1E5D8F' x='416' y='344' width='112' height='80' rx='8' ry='8' />
<path d='M 416 372 L 416 352 Q 416 344 424 344 L 520 344 Q 528 344 528 352 L 528 372 L416 372 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='416' y='344' width='112' height='80' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_role_menu'><text x='425' y='364' >sys_role_menu</text><title>Table ry.sys_role_menu
角色菜单关联表</title></a>
  <use id='nn' x='418' y='381' xlink:href='#nn'/><use id='pk' x='418' y='380' xlink:href='#pk'><title>Pk pk_sys_role_menu ( role_id, menu_id ) </title></use><a xlink:href='#ry.sys_role_menu_role_id'><text id='ry.sys_role_menu.role_id' x='435' y='391'>role_id</text><title>role_id
* int
角色ID</title></a>
<text x='525' y='388' text-anchor='end' class='colType'>#</text>  <use id='nn' x='418' y='397' xlink:href='#nn'/><use id='pk' x='418' y='396' xlink:href='#pk'><title>Pk pk_sys_role_menu ( role_id, menu_id ) </title></use><a xlink:href='#ry.sys_role_menu_menu_id'><text id='ry.sys_role_menu.menu_id' x='435' y='407'>menu_id</text><title>menu_id
* int
菜单ID</title></a>
<text x='525' y='404' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_user_role' == -->
<rect class='entity' style='stroke:#1E5D8F' x='560' y='344' width='96' height='80' rx='8' ry='8' />
<path d='M 560 372 L 560 352 Q 560 344 568 344 L 648 344 Q 656 344 656 352 L 656 372 L560 372 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='560' y='344' width='96' height='80' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_user_role'><text x='565' y='364' >sys_user_role</text><title>Table ry.sys_user_role
用户角色表</title></a>
  <use id='nn' x='562' y='381' xlink:href='#nn'/><use id='pk' x='562' y='380' xlink:href='#pk'><title>Pk pk_sys_user_role ( user_id, role_id ) </title></use><a xlink:href='#ry.sys_user_role_user_id'><text id='ry.sys_user_role.user_id' x='579' y='391'>user_id</text><title>user_id
* int
用户ID</title></a>
<text x='653' y='388' text-anchor='end' class='colType'>#</text>  <use id='nn' x='562' y='397' xlink:href='#nn'/><use id='pk' x='562' y='396' xlink:href='#pk'><title>Pk pk_sys_user_role ( user_id, role_id ) </title></use><a xlink:href='#ry.sys_user_role_role_id'><text id='ry.sys_user_role.role_id' x='579' y='407'>role_id</text><title>role_id
* int
角色ID</title></a>
<text x='653' y='404' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_oper_log' == -->
<rect class='entity' style='stroke:#1E5D8F' x='48' y='472' width='128' height='272' rx='8' ry='8' />
<path d='M 48 500 L 48 480 Q 48 472 56 472 L 168 472 Q 176 472 176 480 L 176 500 L48 500 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='48' y='472' width='128' height='272' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_oper_log'><text x='70' y='492' >sys_oper_log</text><title>Table ry.sys_oper_log
操作日志表</title></a>
  <use id='nn' x='50' y='509' xlink:href='#nn'/><use id='pk' x='50' y='508' xlink:href='#pk'><title>Pk pk_sys_oper_log ( oper_id ) </title></use><a xlink:href='#ry.sys_oper_log_oper_id'><text id='ry.sys_oper_log.oper_id' x='67' y='519'>oper_id</text><title>oper_id
* int
日志主键</title></a>
<text x='173' y='516' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_oper_log_title'><text id='ry.sys_oper_log.title' x='67' y='535'>title</text><title>title
varchar(50) default ''
模块标题</title></a>
<text x='173' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_business_type'><text id='ry.sys_oper_log.business_type' x='67' y='551'>business_type</text><title>business_type
int default 0
业务类型（0其它 1新增 2修改 3删除）</title></a>
<text x='173' y='548' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_oper_log_method'><text id='ry.sys_oper_log.method' x='67' y='567'>method</text><title>method
varchar(100) default ''
方法名称</title></a>
<text x='173' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_operator_type'><text id='ry.sys_oper_log.operator_type' x='67' y='583'>operator_type</text><title>operator_type
int default 0
操作类别（0其它 1后台用户 2手机端用户）</title></a>
<text x='173' y='580' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_oper_log_oper_name'><text id='ry.sys_oper_log.oper_name' x='67' y='599'>oper_name</text><title>oper_name
varchar(50) default ''
操作人员</title></a>
<text x='173' y='596' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_dept_name'><text id='ry.sys_oper_log.dept_name' x='67' y='615'>dept_name</text><title>dept_name
varchar(50) default ''
部门名称</title></a>
<text x='173' y='612' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_oper_url'><text id='ry.sys_oper_log.oper_url' x='67' y='631'>oper_url</text><title>oper_url
varchar(255) default ''
请求URL</title></a>
<text x='173' y='628' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_oper_ip'><text id='ry.sys_oper_log.oper_ip' x='67' y='647'>oper_ip</text><title>oper_ip
varchar(50) default ''
主机地址</title></a>
<text x='173' y='644' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_oper_location'><text id='ry.sys_oper_log.oper_location' x='67' y='663'>oper_location</text><title>oper_location
varchar(1000) default ''
操作地点</title></a>
<text x='173' y='660' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_oper_param'><text id='ry.sys_oper_log.oper_param' x='67' y='679'>oper_param</text><title>oper_param
varchar(2000) default ''
请求参数</title></a>
<text x='173' y='676' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_status'><text id='ry.sys_oper_log.status' x='67' y='695'>status</text><title>status
int default 0
操作状态（0正常 1异常）</title></a>
<text x='173' y='692' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_oper_log_error_msg'><text id='ry.sys_oper_log.error_msg' x='67' y='711'>error_msg</text><title>error_msg
varchar(2000) default ''
错误消息</title></a>
<text x='173' y='708' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_oper_log_oper_time'><text id='ry.sys_oper_log.oper_time' x='67' y='727'>oper_time</text><title>oper_time
datetime
操作时间</title></a>
<text x='173' y='724' text-anchor='end' class='colType'>d</text>
<!-- == Table 'sys_user_online' == -->
<rect class='entity' style='stroke:#1E5D8F' x='224' y='440' width='144' height='224' rx='8' ry='8' />
<path d='M 224 468 L 224 448 Q 224 440 232 440 L 360 440 Q 368 440 368 448 L 368 468 L224 468 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='224' y='440' width='144' height='224' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_user_online'><text x='246' y='460' >sys_user_online</text><title>Table ry.sys_user_online
在线用户表</title></a>
  <use id='nn' x='226' y='477' xlink:href='#nn'/><use id='pk' x='226' y='476' xlink:href='#pk'><title>Pk pk_sys_user_online ( sessionId ) </title></use><a xlink:href='#ry.sys_user_online_sessionId'><text id='ry.sys_user_online.sessionId' x='243' y='487'>sessionId</text><title>sessionId
* varchar(50) default ''
用户会话id</title></a>
<text x='365' y='484' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_login_name'><text id='ry.sys_user_online.login_name' x='243' y='503'>login_name</text><title>login_name
varchar(50) default ''
登录账号</title></a>
<text x='365' y='500' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_dept_name'><text id='ry.sys_user_online.dept_name' x='243' y='519'>dept_name</text><title>dept_name
varchar(50) default ''
部门名称</title></a>
<text x='365' y='516' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_ipaddr'><text id='ry.sys_user_online.ipaddr' x='243' y='535'>ipaddr</text><title>ipaddr
varchar(50) default ''
登录IP地址</title></a>
<text x='365' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_login_location'><text id='ry.sys_user_online.login_location' x='243' y='551'>login_location</text><title>login_location
varchar(255) default ''
登录地点</title></a>
<text x='365' y='548' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_browser'><text id='ry.sys_user_online.browser' x='243' y='567'>browser</text><title>browser
varchar(50) default ''
浏览器类型</title></a>
<text x='365' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_os'><text id='ry.sys_user_online.os' x='243' y='583'>os</text><title>os
varchar(50) default ''
操作系统</title></a>
<text x='365' y='580' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_status'><text id='ry.sys_user_online.status' x='243' y='599'>status</text><title>status
varchar(10) default ''
在线状态on_line在线off_line离线</title></a>
<text x='365' y='596' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_user_online_start_timestamp'><text id='ry.sys_user_online.start_timestamp' x='243' y='615'>start_timestamp</text><title>start_timestamp
datetime
session创建时间</title></a>
<text x='365' y='612' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_user_online_last_access_time'><text id='ry.sys_user_online.last_access_time' x='243' y='631'>last_access_time</text><title>last_access_time
datetime
session最后访问时间</title></a>
<text x='365' y='628' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_user_online_expire_time'><text id='ry.sys_user_online.expire_time' x='243' y='647'>expire_time</text><title>expire_time
int default 0
超时时间，单位为分钟</title></a>
<text x='365' y='644' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_logininfor' == -->
<rect class='entity' style='stroke:#1E5D8F' x='400' y='440' width='128' height='192' rx='8' ry='8' />
<path d='M 400 468 L 400 448 Q 400 440 408 440 L 520 440 Q 528 440 528 448 L 528 468 L400 468 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='400' y='440' width='128' height='192' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_logininfor'><text x='419' y='460' >sys_logininfor</text><title>Table ry.sys_logininfor
登录日志表</title></a>
  <use id='nn' x='402' y='477' xlink:href='#nn'/><use id='pk' x='402' y='476' xlink:href='#pk'><title>Pk pk_sys_logininfor ( info_id ) </title></use><a xlink:href='#ry.sys_logininfor_info_id'><text id='ry.sys_logininfor.info_id' x='419' y='487'>info_id</text><title>info_id
* int
访问ID</title></a>
<text x='525' y='484' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_logininfor_login_name'><text id='ry.sys_logininfor.login_name' x='419' y='503'>login_name</text><title>login_name
varchar(50) default ''
登录账号</title></a>
<text x='525' y='500' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_ipaddr'><text id='ry.sys_logininfor.ipaddr' x='419' y='519'>ipaddr</text><title>ipaddr
varchar(50) default ''
登录IP地址</title></a>
<text x='525' y='516' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_login_location'><text id='ry.sys_logininfor.login_location' x='419' y='535'>login_location</text><title>login_location
varchar(255) default ''
登录地点</title></a>
<text x='525' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_browser'><text id='ry.sys_logininfor.browser' x='419' y='551'>browser</text><title>browser
varchar(50) default ''
浏览器类型</title></a>
<text x='525' y='548' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_os'><text id='ry.sys_logininfor.os' x='419' y='567'>os</text><title>os
varchar(50) default ''
操作系统</title></a>
<text x='525' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_status'><text id='ry.sys_logininfor.status' x='419' y='583'>status</text><title>status
char(1) default '0'
登录状态（0成功 1失败）</title></a>
<text x='525' y='580' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_logininfor_msg'><text id='ry.sys_logininfor.msg' x='419' y='599'>msg</text><title>msg
varchar(255) default ''
提示消息</title></a>
<text x='525' y='596' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_logininfor_login_time'><text id='ry.sys_logininfor.login_time' x='419' y='615'>login_time</text><title>login_time
datetime
访问时间</title></a>
<text x='525' y='612' text-anchor='end' class='colType'>d</text>
<!-- == Table 'sys_mq_queue' == -->
<rect class='entity' style='stroke:#1E5D8F' x='560' y='456' width='112' height='240' rx='8' ry='8' />
<path d='M 560 484 L 560 464 Q 560 456 568 456 L 664 456 Q 672 456 672 464 L 672 484 L560 484 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='560' y='456' width='112' height='240' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_mq_queue'><text x='569' y='476' >sys_mq_queue</text><title>Table ry.sys_mq_queue
MQ队列表</title></a>
  <use id='nn' x='562' y='493' xlink:href='#nn'/><use id='pk' x='562' y='492' xlink:href='#pk'><title>Pk pk_sys_mq_queue ( queue_id ) </title></use><a xlink:href='#ry.sys_mq_queue_queue_id'><text id='ry.sys_mq_queue.queue_id' x='579' y='503'>queue_id</text><title>queue_id
* int
编号</title></a>
<text x='669' y='500' text-anchor='end' class='colType'>#</text>  <use id='nn' x='562' y='509' xlink:href='#nn'/><a xlink:href='#ry.sys_mq_queue_queue_name'><text id='ry.sys_mq_queue.queue_name' x='579' y='519'>queue_name</text><title>queue_name
* varchar(100)
队列名称</title></a>
<text x='669' y='516' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_durability'><text id='ry.sys_mq_queue.durability' x='579' y='535'>durability</text><title>durability
varchar(10)
是否持久化</title></a>
<text x='669' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_auto_delete'><text id='ry.sys_mq_queue.auto_delete' x='579' y='551'>auto_delete</text><title>auto_delete
varchar(10)
不再被使用时(没有任何绑定的情况下），是否由RabbitMQ自动删除</title></a>
<text x='669' y='548' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_arguments'><text id='ry.sys_mq_queue.arguments' x='579' y='567'>arguments</text><title>arguments
varchar(1000)
参数</title></a>
<text x='669' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_routing_key'><text id='ry.sys_mq_queue.routing_key' x='579' y='583'>routing_key</text><title>routing_key
varchar(100)
路由Key</title></a>
<text x='669' y='580' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_app_name'><text id='ry.sys_mq_queue.app_name' x='579' y='599'>app_name</text><title>app_name
varchar(100)
应用名称(被那个系统使用）</title></a>
<text x='669' y='596' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_create_by'><text id='ry.sys_mq_queue.create_by' x='579' y='615'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='669' y='612' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_create_time'><text id='ry.sys_mq_queue.create_time' x='579' y='631'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='669' y='628' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_queue_update_by'><text id='ry.sys_mq_queue.update_by' x='579' y='647'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='669' y='644' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_queue_update_time'><text id='ry.sys_mq_queue.update_time' x='579' y='663'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='669' y='660' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_queue_remark'><text id='ry.sys_mq_queue.remark' x='579' y='679'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='669' y='676' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_ues_en_data' == -->
<rect class='entity' style='stroke:#1E5D8F' x='704' y='392' width='112' height='224' rx='8' ry='8' />
<path d='M 704 420 L 704 400 Q 704 392 712 392 L 808 392 Q 816 392 816 400 L 816 420 L704 420 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='704' y='392' width='112' height='224' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_ues_en_data'><text x='708' y='412' >sys_ues_en_data</text><title>Table ry.sys_ues_en_data
UES数据加密表</title></a>
  <use id='nn' x='706' y='429' xlink:href='#nn'/><use id='pk' x='706' y='428' xlink:href='#pk'><title>Pk pk_sys_ues_en_data ( id ) </title></use><a xlink:href='#ry.sys_ues_en_data_id'><text id='ry.sys_ues_en_data.id' x='723' y='439'>id</text><title>id
* int
编号</title></a>
<text x='813' y='436' text-anchor='end' class='colType'>#</text>  <use id='nn' x='706' y='445' xlink:href='#nn'/><use id='unq' x='706' y='444' xlink:href='#unq'><title>Unq ticket_unique ( ticket ) </title></use><a xlink:href='#ry.sys_ues_en_data_ticket'><text id='ry.sys_ues_en_data.ticket' x='723' y='455'>ticket</text><title>ticket
* varchar(128)
票据</title></a>
<text x='813' y='452' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='461' xlink:href='#nn'/><a xlink:href='#ry.sys_ues_en_data_encrypt_key'><text id='ry.sys_ues_en_data.encrypt_key' x='723' y='471'>encrypt_key</text><title>encrypt_key
* varchar(1024)
加密密码</title></a>
<text x='813' y='468' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='477' xlink:href='#nn'/><a xlink:href='#ry.sys_ues_en_data_encrypt_data'><text id='ry.sys_ues_en_data.encrypt_data' x='723' y='487'>encrypt_data</text><title>encrypt_data
* varchar(2000)
加密密文</title></a>
<text x='813' y='484' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_ues_en_data_version'><text id='ry.sys_ues_en_data.version' x='723' y='503'>version</text><title>version
varchar(10)
版本</title></a>
<text x='813' y='500' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='509' xlink:href='#nn'/><a xlink:href='#ry.sys_ues_en_data_encrypt_type'><text id='ry.sys_ues_en_data.encrypt_type' x='723' y='519'>encrypt_type</text><title>encrypt_type
* varchar(128)
加密类型</title></a>
<text x='813' y='516' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_ues_en_data_create_by'><text id='ry.sys_ues_en_data.create_by' x='723' y='535'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='813' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_ues_en_data_create_time'><text id='ry.sys_ues_en_data.create_time' x='723' y='551'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='813' y='548' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_ues_en_data_update_by'><text id='ry.sys_ues_en_data.update_by' x='723' y='567'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='813' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_ues_en_data_update_time'><text id='ry.sys_ues_en_data.update_time' x='723' y='583'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='813' y='580' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_ues_en_data_remark'><text id='ry.sys_ues_en_data.remark' x='723' y='599'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='813' y='596' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_mq_exchanges' == -->
<rect class='entity' style='stroke:#1E5D8F' x='848' y='376' width='208' height='272' rx='8' ry='8' />
<path d='M 848 404 L 848 384 Q 848 376 856 376 L 1048 376 Q 1056 376 1056 384 L 1056 404 L848 404 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='848' y='376' width='208' height='272' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_mq_exchanges'><text x='892' y='396' >sys_mq_exchanges</text><title>Table ry.sys_mq_exchanges
MQ交换器表</title></a>
  <use id='nn' x='850' y='413' xlink:href='#nn'/><use id='pk' x='850' y='412' xlink:href='#pk'><title>Pk pk_sys_mq_exchanges ( exchanges_id ) </title></use><a xlink:href='#ry.sys_mq_exchanges_exchanges_id'><text id='ry.sys_mq_exchanges.exchanges_id' x='867' y='423'>exchanges_id</text><title>exchanges_id
* int
编号</title></a>
<text x='1053' y='420' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_mq_exchanges_name'><text id='ry.sys_mq_exchanges.name' x='867' y='439'>name</text><title>name
varchar(100)
交换机名称</title></a>
<text x='1053' y='436' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_type'><text id='ry.sys_mq_exchanges.type' x='867' y='455'>type</text><title>type
varchar(10)
类型</title></a>
<text x='1053' y='452' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_durability'><text id='ry.sys_mq_exchanges.durability' x='867' y='471'>durability</text><title>durability
varchar(10)
是否持久化</title></a>
<text x='1053' y='468' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_auto_delete'><text id='ry.sys_mq_exchanges.auto_delete' x='867' y='487'>auto_delete</text><title>auto_delete
varchar(10)
不再被使用时(没有任何绑定的情况下），是否由RabbitMQ自动删除</title></a>
<text x='1053' y='484' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_internal'><text id='ry.sys_mq_exchanges.internal' x='867' y='503'>internal</text><title>internal
varchar(10)
内部的</title></a>
<text x='1053' y='500' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_user_who_performed_action'><text id='ry.sys_mq_exchanges.user_who_performed_action' x='867' y='519'>user_who_performed_action</text><title>user_who_performed_action
varchar(100)
被谁使用</title></a>
<text x='1053' y='516' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_arguments'><text id='ry.sys_mq_exchanges.arguments' x='867' y='535'>arguments</text><title>arguments
varchar(1000)
参数</title></a>
<text x='1053' y='532' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_vhost'><text id='ry.sys_mq_exchanges.vhost' x='867' y='551'>vhost</text><title>vhost
varchar(50)
虚拟主机</title></a>
<text x='1053' y='548' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_create_by'><text id='ry.sys_mq_exchanges.create_by' x='867' y='567'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='1053' y='564' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_create_time'><text id='ry.sys_mq_exchanges.create_time' x='867' y='583'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1053' y='580' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_exchanges_update_by'><text id='ry.sys_mq_exchanges.update_by' x='867' y='599'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='1053' y='596' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_exchanges_update_time'><text id='ry.sys_mq_exchanges.update_time' x='867' y='615'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='1053' y='612' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_exchanges_remark'><text id='ry.sys_mq_exchanges.remark' x='867' y='631'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='1053' y='628' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_mq_exchanges_queue' == -->
<rect class='entity' style='stroke:#1E5D8F' x='1120' y='312' width='176' height='80' rx='8' ry='8' />
<path d='M 1120 340 L 1120 320 Q 1120 312 1128 312 L 1288 312 Q 1296 312 1296 320 L 1296 340 L1120 340 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='1120' y='312' width='176' height='80' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_mq_exchanges_queue'><text x='1126' y='332' >sys_mq_exchanges_queue</text><title>Table ry.sys_mq_exchanges_queue
交换器队列关联表</title></a>
  <use id='nn' x='1122' y='349' xlink:href='#nn'/><use id='pk' x='1122' y='348' xlink:href='#pk'><title>Pk pk_sys_mq_exchanges_queue ( exchanges_id, queue_id ) </title></use><a xlink:href='#ry.sys_mq_exchanges_queue_exchanges_id'><text id='ry.sys_mq_exchanges_queue.exchanges_id' x='1139' y='359'>exchanges_id</text><title>exchanges_id
* int
交换器ID</title></a>
<text x='1293' y='356' text-anchor='end' class='colType'>#</text>  <use id='nn' x='1122' y='365' xlink:href='#nn'/><use id='pk' x='1122' y='364' xlink:href='#pk'><title>Pk pk_sys_mq_exchanges_queue ( exchanges_id, queue_id ) </title></use><a xlink:href='#ry.sys_mq_exchanges_queue_queue_id'><text id='ry.sys_mq_exchanges_queue.queue_id' x='1139' y='375'>queue_id</text><title>queue_id
* int
队列ID</title></a>
<text x='1293' y='372' text-anchor='end' class='colType'>#</text>
<!-- == Table 'sys_mq_message_log' == -->
<rect class='entity' style='stroke:#1E5D8F' x='1120' y='408' width='144' height='192' rx='8' ry='8' />
<path d='M 1120 436 L 1120 416 Q 1120 408 1128 408 L 1256 408 Q 1264 408 1264 416 L 1264 436 L1120 436 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='1120' y='408' width='144' height='192' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_mq_message_log'><text x='1125' y='428' >sys_mq_message_log</text><title>Table ry.sys_mq_message_log
MQ消息发送表</title></a>
  <use id='nn' x='1122' y='445' xlink:href='#nn'/><use id='pk' x='1122' y='444' xlink:href='#pk'><title>Pk pk_sys_mq_message_log ( message_id ) </title></use><a xlink:href='#ry.sys_mq_message_log_message_id'><text id='ry.sys_mq_message_log.message_id' x='1139' y='455'>message_id</text><title>message_id
* varchar(128)
消息唯一ID</title></a>
<text x='1261' y='452' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_message_log_message'><text id='ry.sys_mq_message_log.message' x='1139' y='471'>message</text><title>message
varchar(5000)
消息内容</title></a>
<text x='1261' y='468' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_message_log_try_count'><text id='ry.sys_mq_message_log.try_count' x='1139' y='487'>try_count</text><title>try_count
int default 0
重试次数</title></a>
<text x='1261' y='484' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_mq_message_log_status'><text id='ry.sys_mq_message_log.status' x='1139' y='503'>status</text><title>status
varchar(10) default ''
消息投递状态 0 投递中 1 投递成功 2 投递失败</title></a>
<text x='1261' y='500' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_mq_message_log_next_retry'><text id='ry.sys_mq_message_log.next_retry' x='1139' y='519'>next_retry</text><title>next_retry
timestamp
下一次重试时间 或 超时时间</title></a>
<text x='1261' y='516' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_message_log_create_time'><text id='ry.sys_mq_message_log.create_time' x='1139' y='535'>create_time</text><title>create_time
timestamp
创建时间</title></a>
<text x='1261' y='532' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_mq_message_log_update_time'><text id='ry.sys_mq_message_log.update_time' x='1139' y='551'>update_time</text><title>update_time
timestamp
更新时间</title></a>
<text x='1261' y='548' text-anchor='end' class='colType'>d</text>  <use id='nn' x='1122' y='557' xlink:href='#nn'/><a xlink:href='#ry.sys_mq_message_log_exchange'><text id='ry.sys_mq_message_log.exchange' x='1139' y='567'>exchange</text><title>exchange
* varchar(200)
交换器</title></a>
<text x='1261' y='564' text-anchor='end' class='colType'>t</text>  <use id='nn' x='1122' y='573' xlink:href='#nn'/><a xlink:href='#ry.sys_mq_message_log_routing_key'><text id='ry.sys_mq_message_log.routing_key' x='1139' y='583'>routing_key</text><title>routing_key
* varchar(200)
路由key</title></a>
<text x='1261' y='580' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_job_log' == -->
<rect class='entity' style='stroke:#1E5D8F' x='1072' y='680' width='144' height='192' rx='8' ry='8' />
<path d='M 1072 708 L 1072 688 Q 1072 680 1080 680 L 1208 680 Q 1216 680 1216 688 L 1216 708 L1072 708 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='1072' y='680' width='144' height='192' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_job_log'><text x='1106' y='700' >sys_job_log</text><title>Table ry.sys_job_log
任务日志表</title></a>
  <use id='nn' x='1074' y='717' xlink:href='#nn'/><use id='pk' x='1074' y='716' xlink:href='#pk'><title>Pk pk_sys_job_log ( job_log_id ) </title></use><a xlink:href='#ry.sys_job_log_job_log_id'><text id='ry.sys_job_log.job_log_id' x='1091' y='727'>job_log_id</text><title>job_log_id
* int
任务日志ID</title></a>
<text x='1213' y='724' text-anchor='end' class='colType'>#</text>  <use id='nn' x='1074' y='733' xlink:href='#nn'/><a xlink:href='#ry.sys_job_log_job_name'><text id='ry.sys_job_log.job_name' x='1091' y='743'>job_name</text><title>job_name
* varchar(64)
任务名称</title></a>
<text x='1213' y='740' text-anchor='end' class='colType'>t</text>  <use id='nn' x='1074' y='749' xlink:href='#nn'/><a xlink:href='#ry.sys_job_log_job_group'><text id='ry.sys_job_log.job_group' x='1091' y='759'>job_group</text><title>job_group
* varchar(64)
任务组名</title></a>
<text x='1213' y='756' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_log_method_name'><text id='ry.sys_job_log.method_name' x='1091' y='775'>method_name</text><title>method_name
varchar(500)
任务方法</title></a>
<text x='1213' y='772' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_log_method_params'><text id='ry.sys_job_log.method_params' x='1091' y='791'>method_params</text><title>method_params
varchar(50)
方法参数</title></a>
<text x='1213' y='788' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_log_job_message'><text id='ry.sys_job_log.job_message' x='1091' y='807'>job_message</text><title>job_message
varchar(500)
日志信息</title></a>
<text x='1213' y='804' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_log_status'><text id='ry.sys_job_log.status' x='1091' y='823'>status</text><title>status
char(1) default '0'
执行状态（0正常 1失败）</title></a>
<text x='1213' y='820' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_job_log_exception_info'><text id='ry.sys_job_log.exception_info' x='1091' y='839'>exception_info</text><title>exception_info
varchar(2000) default ''
异常信息</title></a>
<text x='1213' y='836' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_log_create_time'><text id='ry.sys_job_log.create_time' x='1091' y='855'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1213' y='852' text-anchor='end' class='colType'>d</text>
<!-- == Table 'sys_job' == -->
<rect class='entity' style='stroke:#1E5D8F' x='880' y='680' width='144' height='256' rx='8' ry='8' />
<path d='M 880 708 L 880 688 Q 880 680 888 680 L 1016 680 Q 1024 680 1024 688 L 1024 708 L880 708 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='880' y='680' width='144' height='256' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_job'><text x='926' y='700' >sys_job</text><title>Table ry.sys_job
定时任务表</title></a>
  <use id='nn' x='882' y='717' xlink:href='#nn'/><use id='pk' x='882' y='716' xlink:href='#pk'><title>Pk pk_sys_job ( job_id, job_name, job_group ) </title></use><a xlink:href='#ry.sys_job_job_id'><text id='ry.sys_job.job_id' x='899' y='727'>job_id</text><title>job_id
* int
任务ID</title></a>
<text x='1021' y='724' text-anchor='end' class='colType'>#</text>  <use id='nn' x='882' y='733' xlink:href='#nn'/><use id='pk' x='882' y='732' xlink:href='#pk'><title>Pk pk_sys_job ( job_id, job_name, job_group ) </title></use><a xlink:href='#ry.sys_job_job_name'><text id='ry.sys_job.job_name' x='899' y='743'>job_name</text><title>job_name
* varchar(64) default ''
任务名称</title></a>
<text x='1021' y='740' text-anchor='end' class='colType'>t</text>  <use id='nn' x='882' y='749' xlink:href='#nn'/><use id='pk' x='882' y='748' xlink:href='#pk'><title>Pk pk_sys_job ( job_id, job_name, job_group ) </title></use><a xlink:href='#ry.sys_job_job_group'><text id='ry.sys_job.job_group' x='899' y='759'>job_group</text><title>job_group
* varchar(64) default ''
任务组名</title></a>
<text x='1021' y='756' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_method_name'><text id='ry.sys_job.method_name' x='899' y='775'>method_name</text><title>method_name
varchar(500) default ''
任务方法</title></a>
<text x='1021' y='772' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_method_params'><text id='ry.sys_job.method_params' x='899' y='791'>method_params</text><title>method_params
varchar(50)
方法参数</title></a>
<text x='1021' y='788' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_cron_expression'><text id='ry.sys_job.cron_expression' x='899' y='807'>cron_expression</text><title>cron_expression
varchar(255) default ''
cron执行表达式</title></a>
<text x='1021' y='804' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_misfire_policy'><text id='ry.sys_job.misfire_policy' x='899' y='823'>misfire_policy</text><title>misfire_policy
varchar(20) default '3'
计划执行错误策略（1立即执行 2执行一次 3放弃执行）</title></a>
<text x='1021' y='820' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_status'><text id='ry.sys_job.status' x='899' y='839'>status</text><title>status
char(1) default '0'
状态（0正常 1暂停）</title></a>
<text x='1021' y='836' text-anchor='end' class='colType'>c</text>  <a xlink:href='#ry.sys_job_create_by'><text id='ry.sys_job.create_by' x='899' y='855'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='1021' y='852' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_create_time'><text id='ry.sys_job.create_time' x='899' y='871'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='1021' y='868' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_job_update_by'><text id='ry.sys_job.update_by' x='899' y='887'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='1021' y='884' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_job_update_time'><text id='ry.sys_job.update_time' x='899' y='903'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='1021' y='900' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_job_remark'><text id='ry.sys_job.remark' x='899' y='919'>remark</text><title>remark
varchar(500) default ''
备注信息</title></a>
<text x='1021' y='916' text-anchor='end' class='colType'>t</text>
<!-- == Table 'notify_msg_log' == -->
<rect class='entity' style='stroke:#1E5D8F' x='704' y='680' width='144' height='288' rx='8' ry='8' />
<path d='M 704 708 L 704 688 Q 704 680 712 680 L 840 680 Q 848 680 848 688 L 848 708 L704 708 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='704' y='680' width='144' height='288' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.notify_msg_log'><text x='727' y='700' >notify_msg_log</text><title>Table ry.notify_msg_log
消息通知日志</title></a>
  <use id='nn' x='706' y='717' xlink:href='#nn'/><use id='pk' x='706' y='716' xlink:href='#pk'><title>Pk pk_notify_msg_log ( id ) </title></use><a xlink:href='#ry.notify_msg_log_id'><text id='ry.notify_msg_log.id' x='723' y='727'>id</text><title>id
* int</title></a>
<text x='845' y='724' text-anchor='end' class='colType'>#</text>  <use id='nn' x='706' y='733' xlink:href='#nn'/><a xlink:href='#ry.notify_msg_log_msg_order_no'><text id='ry.notify_msg_log.msg_order_no' x='723' y='743'>msg_order_no</text><title>msg_order_no
* varchar(50)
信息发送流水号</title></a>
<text x='845' y='740' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_remarks'><text id='ry.notify_msg_log.remarks' x='723' y='759'>remarks</text><title>remarks
varchar(255)
备注信息(信息返回BizId)</title></a>
<text x='845' y='756' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='765' xlink:href='#nn'/><a xlink:href='#ry.notify_msg_log_business_type'><text id='ry.notify_msg_log.business_type' x='723' y='775'>business_type</text><title>business_type
* varchar(4)
业务类型</title></a>
<text x='845' y='772' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='781' xlink:href='#nn'/><a xlink:href='#ry.notify_msg_log_phone'><text id='ry.notify_msg_log.phone' x='723' y='791'>phone</text><title>phone
* longtext
联系电话</title></a>
<text x='845' y='788' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_template_id'><text id='ry.notify_msg_log.template_id' x='723' y='807'>template_id</text><title>template_id
varchar(1000)
模板ID</title></a>
<text x='845' y='804' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_template_content'><text id='ry.notify_msg_log.template_content' x='723' y='823'>template_content</text><title>template_content
longtext
模板类型</title></a>
<text x='845' y='820' text-anchor='end' class='colType'>t</text>  <use id='nn' x='706' y='829' xlink:href='#nn'/><a xlink:href='#ry.notify_msg_log_senddata'><text id='ry.notify_msg_log.senddata' x='723' y='839'>senddata</text><title>senddata
* datetime
发送数据</title></a>
<text x='845' y='836' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.notify_msg_log_status'><text id='ry.notify_msg_log.status' x='723' y='855'>status</text><title>status
varchar(4)
发送状态</title></a>
<text x='845' y='852' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_smsid'><text id='ry.notify_msg_log.smsid' x='723' y='871'>smsid</text><title>smsid
varchar(50)
发送响应消息ID</title></a>
<text x='845' y='868' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_code'><text id='ry.notify_msg_log.code' x='723' y='887'>code</text><title>code
varchar(40)
返回码</title></a>
<text x='845' y='884' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_msg'><text id='ry.notify_msg_log.msg' x='723' y='903'>msg</text><title>msg
varchar(40)
返回消息</title></a>
<text x='845' y='900' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_del_flag'><text id='ry.notify_msg_log.del_flag' x='723' y='919'>del_flag</text><title>del_flag
varchar(1) default '0'
删除标记（0：正常；1：删除）</title></a>
<text x='845' y='916' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.notify_msg_log_response_date'><text id='ry.notify_msg_log.response_date' x='723' y='935'>response_date</text><title>response_date
datetime
响应时间</title></a>
<text x='845' y='932' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.notify_msg_log_verify_code'><text id='ry.notify_msg_log.verify_code' x='723' y='951'>verify_code</text><title>verify_code
varchar(10)
短信验证码</title></a>
<text x='845' y='948' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_sms_template' == -->
<rect class='entity' style='stroke:#1E5D8F' x='512' y='696' width='144' height='240' rx='8' ry='8' />
<path d='M 512 724 L 512 704 Q 512 696 520 696 L 648 696 Q 656 696 656 704 L 656 724 L512 724 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='512' y='696' width='144' height='240' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_sms_template'><text x='527' y='716' >sys_sms_template</text><title>Table ry.sys_sms_template
短息模板</title></a>
  <use id='nn' x='514' y='733' xlink:href='#nn'/><use id='pk' x='514' y='732' xlink:href='#pk'><title>Pk pk_sys_sms_template ( id ) </title></use><a xlink:href='#ry.sys_sms_template_id'><text id='ry.sys_sms_template.id' x='531' y='743'>id</text><title>id
* int</title></a>
<text x='653' y='740' text-anchor='end' class='colType'>#</text>  <use id='nn' x='514' y='749' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_name'><text id='ry.sys_sms_template.name' x='531' y='759'>name</text><title>name
* varchar(255)
模版名称</title></a>
<text x='653' y='756' text-anchor='end' class='colType'>t</text>  <use id='nn' x='514' y='765' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_code'><text id='ry.sys_sms_template.code' x='531' y='775'>code</text><title>code
* varchar(255)
模版编码</title></a>
<text x='653' y='772' text-anchor='end' class='colType'>t</text>  <use id='nn' x='514' y='781' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_business_type'><text id='ry.sys_sms_template.business_type' x='531' y='791'>business_type</text><title>business_type
* varchar(4)
业务类型</title></a>
<text x='653' y='788' text-anchor='end' class='colType'>t</text>  <use id='nn' x='514' y='797' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_template_id'><text id='ry.sys_sms_template.template_id' x='531' y='807'>template_id</text><title>template_id
* varchar(20)
模版ID</title></a>
<text x='653' y='804' text-anchor='end' class='colType'>t</text>  <use id='nn' x='514' y='813' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_template_content'><text id='ry.sys_sms_template.template_content' x='531' y='823'>template_content</text><title>template_content
* varchar(2000)
模版内容</title></a>
<text x='653' y='820' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_template_create_by'><text id='ry.sys_sms_template.create_by' x='531' y='839'>create_by</text><title>create_by
varchar(32)
创建者</title></a>
<text x='653' y='836' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_template_create_date'><text id='ry.sys_sms_template.create_date' x='531' y='855'>create_date</text><title>create_date
datetime
创建时间</title></a>
<text x='653' y='852' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_sms_template_update_by'><text id='ry.sys_sms_template.update_by' x='531' y='871'>update_by</text><title>update_by
varchar(32)
更新者</title></a>
<text x='653' y='868' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_template_update_date'><text id='ry.sys_sms_template.update_date' x='531' y='887'>update_date</text><title>update_date
datetime
更新时间</title></a>
<text x='653' y='884' text-anchor='end' class='colType'>d</text>  <use id='nn' x='514' y='893' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_template_del_flag'><text id='ry.sys_sms_template.del_flag' x='531' y='903'>del_flag</text><title>del_flag
* varchar(1) default '0'
删除标记（0：正常；1：删除）</title></a>
<text x='653' y='900' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_template_remarks'><text id='ry.sys_sms_template.remarks' x='531' y='919'>remarks</text><title>remarks
varchar(255)
备注信息</title></a>
<text x='653' y='916' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_sms_config' == -->
<rect class='entity' style='stroke:#1E5D8F' x='368' y='696' width='112' height='208' rx='8' ry='8' />
<path d='M 368 724 L 368 704 Q 368 696 376 696 L 472 696 Q 480 696 480 704 L 480 724 L368 724 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='368' y='696' width='112' height='208' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_sms_config'><text x='375' y='716' >sys_sms_config</text><title>Table ry.sys_sms_config
短息配置</title></a>
  <use id='nn' x='370' y='733' xlink:href='#nn'/><use id='pk' x='370' y='732' xlink:href='#pk'><title>Pk pk_sys_sms_config ( id ) </title></use><a xlink:href='#ry.sys_sms_config_id'><text id='ry.sys_sms_config.id' x='387' y='743'>id</text><title>id
* int
主键</title></a>
<text x='477' y='740' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_sms_config_name'><text id='ry.sys_sms_config.name' x='387' y='759'>name</text><title>name
varchar(255)
名称</title></a>
<text x='477' y='756' text-anchor='end' class='colType'>t</text>  <use id='nn' x='370' y='765' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_config_sms_key'><text id='ry.sys_sms_config.sms_key' x='387' y='775'>sms_key</text><title>sms_key
* varchar(500)
键</title></a>
<text x='477' y='772' text-anchor='end' class='colType'>t</text>  <use id='nn' x='370' y='781' xlink:href='#nn'/><a xlink:href='#ry.sys_sms_config_sms_value'><text id='ry.sys_sms_config.sms_value' x='387' y='791'>sms_value</text><title>sms_value
* varchar(500)
值</title></a>
<text x='477' y='788' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_config_create_by'><text id='ry.sys_sms_config.create_by' x='387' y='807'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='477' y='804' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_config_create_time'><text id='ry.sys_sms_config.create_time' x='387' y='823'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='477' y='820' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_sms_config_update_by'><text id='ry.sys_sms_config.update_by' x='387' y='839'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='477' y='836' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_config_update_time'><text id='ry.sys_sms_config.update_time' x='387' y='855'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='477' y='852' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_sms_config_remark'><text id='ry.sys_sms_config.remark' x='387' y='871'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='477' y='868' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_sms_config_del_flag'><text id='ry.sys_sms_config.del_flag' x='387' y='887'>del_flag</text><title>del_flag
char(1) default '0'
删除标志（0代表存在 2代表删除）</title></a>
<text x='477' y='884' text-anchor='end' class='colType'>c</text>
<!-- == Table 'sys_file_info' == -->
<rect class='entity' style='stroke:#1E5D8F' x='48' y='744' width='128' height='304' rx='8' ry='8' />
<path d='M 48 772 L 48 752 Q 48 744 56 744 L 168 744 Q 176 744 176 752 L 176 772 L48 772 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='48' y='744' width='128' height='304' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_file_info'><text x='73' y='764' >sys_file_info</text><title>Table ry.sys_file_info
文件信息表</title></a>
  <use id='nn' x='50' y='781' xlink:href='#nn'/><use id='pk' x='50' y='780' xlink:href='#pk'><title>Pk pk_sys_file_info ( id ) </title></use><a xlink:href='#ry.sys_file_info_id'><text id='ry.sys_file_info.id' x='67' y='791'>id</text><title>id
* int
编号</title></a>
<text x='173' y='788' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_file_info_new_name'><text id='ry.sys_file_info.new_name' x='67' y='807'>new_name</text><title>new_name
varchar(255)
新名字</title></a>
<text x='173' y='804' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_old_name'><text id='ry.sys_file_info.old_name' x='67' y='823'>old_name</text><title>old_name
varchar(255)
原文件名</title></a>
<text x='173' y='820' text-anchor='end' class='colType'>t</text>  <use id='nn' x='50' y='829' xlink:href='#nn'/><a xlink:href='#ry.sys_file_info_size'><text id='ry.sys_file_info.size' x='67' y='839'>size</text><title>size
* bigint
文件大小</title></a>
<text x='173' y='836' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_file_info_suffix'><text id='ry.sys_file_info.suffix' x='67' y='855'>suffix</text><title>suffix
varchar(255)
文件后缀</title></a>
<text x='173' y='852' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_css_style'><text id='ry.sys_file_info.css_style' x='67' y='871'>css_style</text><title>css_style
varchar(255)
样式</title></a>
<text x='173' y='868' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_type'><text id='ry.sys_file_info.type' x='67' y='887'>type</text><title>type
varchar(255)
类型  1文档2图片4音乐3视频5其它</title></a>
<text x='173' y='884' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_bucket_name'><text id='ry.sys_file_info.bucket_name' x='67' y='903'>bucket_name</text><title>bucket_name
varchar(255)
文件存储空间名</title></a>
<text x='173' y='900' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_oss_url'><text id='ry.sys_file_info.oss_url' x='67' y='919'>oss_url</text><title>oss_url
varchar(500)
OSS文件路径</title></a>
<text x='173' y='916' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_file_name'><text id='ry.sys_file_info.file_name' x='67' y='935'>file_name</text><title>file_name
varchar(100)
文件夹名称</title></a>
<text x='173' y='932' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_lable'><text id='ry.sys_file_info.lable' x='67' y='951'>lable</text><title>lable
varchar(500)
标签</title></a>
<text x='173' y='948' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_create_by'><text id='ry.sys_file_info.create_by' x='67' y='967'>create_by</text><title>create_by
varchar(64) default ''
创建者</title></a>
<text x='173' y='964' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_create_time'><text id='ry.sys_file_info.create_time' x='67' y='983'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='173' y='980' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_file_info_update_by'><text id='ry.sys_file_info.update_by' x='67' y='999'>update_by</text><title>update_by
varchar(64) default ''
更新者</title></a>
<text x='173' y='996' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_file_info_update_time'><text id='ry.sys_file_info.update_time' x='67' y='1015'>update_time</text><title>update_time
datetime
更新时间</title></a>
<text x='173' y='1012' text-anchor='end' class='colType'>d</text>  <a xlink:href='#ry.sys_file_info_remark'><text id='ry.sys_file_info.remark' x='67' y='1031'>remark</text><title>remark
varchar(500) default ''
备注</title></a>
<text x='173' y='1028' text-anchor='end' class='colType'>t</text>
<!-- == Table 'sys_email' == -->
<rect class='entity' style='stroke:#1E5D8F' x='208' y='696' width='128' height='272' rx='8' ry='8' />
<path d='M 208 724 L 208 704 Q 208 696 216 696 L 328 696 Q 336 696 336 704 L 336 724 L208 724 ' style='fill:url(#tbg_3986C1);stroke:1;stroke-opacity:0.1;' />
<rect class='entity' x='208' y='696' width='128' height='272' rx='8' ry='8' style='fill:none;stroke:#DADDE1'/>
<a xlink:href='#ry.sys_email'><text x='240' y='716' >sys_email</text><title>Table ry.sys_email
Email邮件</title></a>
  <use id='nn' x='210' y='733' xlink:href='#nn'/><use id='pk' x='210' y='732' xlink:href='#pk'><title>Pk pk_sys_email ( email_id ) </title></use><a xlink:href='#ry.sys_email_email_id'><text id='ry.sys_email.email_id' x='227' y='743'>email_id</text><title>email_id
* int
邮箱编号</title></a>
<text x='333' y='740' text-anchor='end' class='colType'>#</text>  <use id='nn' x='210' y='749' xlink:href='#nn'/><a xlink:href='#ry.sys_email_email_site'><text id='ry.sys_email.email_site' x='227' y='759'>email_site</text><title>email_site
* int default 0
0：站内信；1：站外信</title></a>
<text x='333' y='756' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_email_form_user'><text id='ry.sys_email.form_user' x='227' y='775'>form_user</text><title>form_user
int
用户编号，发送方</title></a>
<text x='333' y='772' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_email_to_user'><text id='ry.sys_email.to_user' x='227' y='791'>to_user</text><title>to_user
int
用户编号，接收方</title></a>
<text x='333' y='788' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_email_to_user_email'><text id='ry.sys_email.to_user_email' x='227' y='807'>to_user_email</text><title>to_user_email
varchar(30) default ''
接收方邮件地址</title></a>
<text x='333' y='804' text-anchor='end' class='colType'>t</text>  <use id='nn' x='210' y='813' xlink:href='#nn'/><a xlink:href='#ry.sys_email_email_subject'><text id='ry.sys_email.email_subject' x='227' y='823'>email_subject</text><title>email_subject
* varchar(30)
邮件主题</title></a>
<text x='333' y='820' text-anchor='end' class='colType'>t</text>  <use id='nn' x='210' y='829' xlink:href='#nn'/><a xlink:href='#ry.sys_email_email_content'><text id='ry.sys_email.email_content' x='227' y='839'>email_content</text><title>email_content
* text
邮件内容</title></a>
<text x='333' y='836' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_email_email_status'><text id='ry.sys_email.email_status' x='227' y='855'>email_status</text><title>email_status
int default 0
邮件状态(0：正常；1：已删除）</title></a>
<text x='333' y='852' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_email_email_type'><text id='ry.sys_email.email_type' x='227' y='871'>email_type</text><title>email_type
varchar(50) default ''
邮件类型(例：工作，广告，文档等，可在字典中配置)</title></a>
<text x='333' y='868' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_email_email_folder'><text id='ry.sys_email.email_folder' x='227' y='887'>email_folder</text><title>email_folder
varchar(50) default '1'
邮件形式(例：收件箱，重要，草稿，垃圾箱等，可在字典中配置))</title></a>
<text x='333' y='884' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_email_email_label'><text id='ry.sys_email.email_label' x='227' y='903'>email_label</text><title>email_label
varchar(50) default ''
邮件标签(例：朋友；音乐，家庭，自定义标签，可在字典中配置)</title></a>
<text x='333' y='900' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_email_send_status'><text id='ry.sys_email.send_status' x='227' y='919'>send_status</text><title>send_status
int default 0
发送邮件状态(0：成功；1：失败)</title></a>
<text x='333' y='916' text-anchor='end' class='colType'>#</text>  <a xlink:href='#ry.sys_email_create_by'><text id='ry.sys_email.create_by' x='227' y='935'>create_by</text><title>create_by
varchar(20) default ''
创建者</title></a>
<text x='333' y='932' text-anchor='end' class='colType'>t</text>  <a xlink:href='#ry.sys_email_create_time'><text id='ry.sys_email.create_time' x='227' y='951'>create_time</text><title>create_time
datetime
创建时间</title></a>
<text x='333' y='948' text-anchor='end' class='colType'>d</text>
</g></svg></div>
<div class='container'>

<div class='card'><div class='card-body'>
<h5 class='card-title'>Tables</h5>
<ul>
<li><a href='#ry.notify_msg_log'/>ry.notify_msg_log</a>
<li><a href='#ry.sys_config'/>ry.sys_config</a>
<li><a href='#ry.sys_dept'/>ry.sys_dept</a>
<li><a href='#ry.sys_dict_data'/>ry.sys_dict_data</a>
<li><a href='#ry.sys_dict_type'/>ry.sys_dict_type</a>
<li><a href='#ry.sys_email'/>ry.sys_email</a>
<li><a href='#ry.sys_file_info'/>ry.sys_file_info</a>
<li><a href='#ry.sys_job'/>ry.sys_job</a>
<li><a href='#ry.sys_job_log'/>ry.sys_job_log</a>
<li><a href='#ry.sys_logininfor'/>ry.sys_logininfor</a>
<li><a href='#ry.sys_menu'/>ry.sys_menu</a>
<li><a href='#ry.sys_mq_exchanges'/>ry.sys_mq_exchanges</a>
<li><a href='#ry.sys_mq_exchanges_queue'/>ry.sys_mq_exchanges_queue</a>
<li><a href='#ry.sys_mq_message_log'/>ry.sys_mq_message_log</a>
<li><a href='#ry.sys_mq_queue'/>ry.sys_mq_queue</a>
<li><a href='#ry.sys_notice'/>ry.sys_notice</a>
<li><a href='#ry.sys_oper_log'/>ry.sys_oper_log</a>
<li><a href='#ry.sys_post'/>ry.sys_post</a>
<li><a href='#ry.sys_role'/>ry.sys_role</a>
<li><a href='#ry.sys_role_dept'/>ry.sys_role_dept</a>
<li><a href='#ry.sys_role_menu'/>ry.sys_role_menu</a>
<li><a href='#ry.sys_sms_config'/>ry.sys_sms_config</a>
<li><a href='#ry.sys_sms_template'/>ry.sys_sms_template</a>
<li><a href='#ry.sys_ues_en_data'/>ry.sys_ues_en_data</a>
<li><a href='#ry.sys_user'/>ry.sys_user</a>
<li><a href='#ry.sys_user_online'/>ry.sys_user_online</a>
<li><a href='#ry.sys_user_post'/>ry.sys_user_post</a>
<li><a href='#ry.sys_user_role'/>ry.sys_user_role</a></ul>
</div></div><br><br><br><br>
<div class='card'><div class='card-body'><a name='ry.notify_msg_log' onclick='window.scrollTo(504, 688);return false;' style='cursor:pointer;'><h5 class='card-title'>Table notify_msg_log</h5></a>
<p class="text-muted">消息通知日志</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.notify_msg_log_id'>id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td>  </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.notify_msg_log_msg_order_no'>msg&#95;order&#95;no</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 信息发送流水号 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_remarks'>remarks</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 备注信息&#40;信息返回BizId&#41; </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.notify_msg_log_business_type'>business&#95;type</a></td>
		<td> varchar&#40; 4 &#41;   </td>
		<td> 业务类型 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.notify_msg_log_phone'>phone</a></td>
		<td> longtext   </td>
		<td> 联系电话 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_template_id'>template&#95;id</a></td>
		<td> varchar&#40; 1000 &#41;   </td>
		<td> 模板ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_template_content'>template&#95;content</a></td>
		<td> longtext   </td>
		<td> 模板类型 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.notify_msg_log_senddata'>senddata</a></td>
		<td> datetime   </td>
		<td> 发送数据 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_status'>status</a></td>
		<td> varchar&#40; 4 &#41;   </td>
		<td> 发送状态 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_smsid'>smsid</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 发送响应消息ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_code'>code</a></td>
		<td> varchar&#40; 40 &#41;   </td>
		<td> 返回码 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_msg'>msg</a></td>
		<td> varchar&#40; 40 &#41;   </td>
		<td> 返回消息 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_del_flag'>del&#95;flag</a></td>
		<td> varchar&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标记（0：正常；1：删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_response_date'>response&#95;date</a></td>
		<td> datetime   </td>
		<td> 响应时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.notify_msg_log_verify_code'>verify&#95;code</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 短信验证码 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;notify&#95;msg&#95;log</td>
		<td> ON id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_config' onclick='window.scrollTo(584, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_config</h5></a>
<p class="text-muted">系统设置</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_config_config_id'>config&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 参数主键 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_config_name'>config&#95;name</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 参数名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_config_key'>config&#95;key</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 参数键名 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_config_value'>config&#95;value</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 参数键值 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_config_type'>config&#95;type</a></td>
		<td> char&#40; 1 &#41;   DEFAULT 'N' </td>
		<td> 系统内置（Y是 N否） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_config_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;config</td>
		<td> ON config&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_dept' onclick='window.scrollTo(60, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_dept</h5></a>
<p class="text-muted">部门表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_dept_dept_id'>dept&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 部门id </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_parent_id'>parent&#95;id</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 父部门id </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_ancestors'>ancestors</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 祖级列表 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_dept_name'>dept&#95;name</a></td>
		<td> varchar&#40; 30 &#41;   DEFAULT '' </td>
		<td> 部门名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_order_num'>order&#95;num</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 显示顺序 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_leader'>leader</a></td>
		<td> varchar&#40; 20 &#41;   </td>
		<td> 负责人 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_phone'>phone</a></td>
		<td> varchar&#40; 11 &#41;   </td>
		<td> 联系电话 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_email'>email</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 邮箱 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 部门状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_del_flag'>del&#95;flag</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标志（0代表存在 2代表删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dept_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;dept</td>
		<td> ON dept&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_dict_data' onclick='window.scrollTo(728, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_dict_data</h5></a>
<p class="text-muted">数据字典</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_dict_data_dict_code'>dict&#95;code</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 字典编码 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_dict_sort'>dict&#95;sort</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 字典排序 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_dict_label'>dict&#95;label</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 字典标签 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_dict_value'>dict&#95;value</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 字典键值 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_dict_type'>dict&#95;type</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 字典类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_dict_link'>dict&#95;link</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 连接地址 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_css_class'>css&#95;class</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 样式属性（其他样式扩展） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_list_class'>list&#95;class</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 表格回显样式 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_is_default'>is&#95;default</a></td>
		<td> char&#40; 1 &#41;   DEFAULT 'N' </td>
		<td> 是否默认（Y是 N否） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_data_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;dict&#95;data</td>
		<td> ON dict&#95;code</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_dict_type' onclick='window.scrollTo(872, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_dict_type</h5></a>
<p class="text-muted">数据字典类型</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_dict_type_dict_id'>dict&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 字典主键 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_dict_name'>dict&#95;name</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 字典名称 </td>
	</tr>
	<tr>
		<td><svg width='14' height='14'><use xlink:href='#unq'/></svg></td>
		<td><a name='ry.sys_dict_type_dict_type'>dict&#95;type</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 字典类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_dict_type_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;dict&#95;type</td>
		<td> ON dict&#95;id</td>
		<td>  </td>
	</tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#unq'/></svg></td><td>dict&#95;type</td>
		<td> ON dict&#95;type</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_email' onclick='window.scrollTo(60, 704);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_email</h5></a>
<p class="text-muted">Email邮件</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_email_email_id'>email&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 邮箱编号 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_email_email_site'>email&#95;site</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 0：站内信；1：站外信 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_form_user'>form&#95;user</a></td>
		<td> int   </td>
		<td> 用户编号，发送方 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_to_user'>to&#95;user</a></td>
		<td> int   </td>
		<td> 用户编号，接收方 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_to_user_email'>to&#95;user&#95;email</a></td>
		<td> varchar&#40; 30 &#41;   DEFAULT '' </td>
		<td> 接收方邮件地址 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_email_email_subject'>email&#95;subject</a></td>
		<td> varchar&#40; 30 &#41;   </td>
		<td> 邮件主题 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_email_email_content'>email&#95;content</a></td>
		<td> text   </td>
		<td> 邮件内容 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_email_status'>email&#95;status</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 邮件状态&#40;0：正常；1：已删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_email_type'>email&#95;type</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 邮件类型&#40;例：工作，广告，文档等，可在字典中配置&#41; </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_email_folder'>email&#95;folder</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '1' </td>
		<td> 邮件形式&#40;例：收件箱，重要，草稿，垃圾箱等，可在字典中配置&#41;&#41; </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_email_label'>email&#95;label</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 邮件标签&#40;例：朋友；音乐，家庭，自定义标签，可在字典中配置&#41; </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_send_status'>send&#95;status</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 发送邮件状态&#40;0：成功；1：失败&#41; </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 20 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_email_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;email</td>
		<td> ON email&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_file_info' onclick='window.scrollTo(60, 752);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_file_info</h5></a>
<p class="text-muted">文件信息表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_file_info_id'>id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 编号 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_new_name'>new&#95;name</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 新名字 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_old_name'>old&#95;name</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 原文件名 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_file_info_size'>size</a></td>
		<td> bigint   </td>
		<td> 文件大小 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_suffix'>suffix</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 文件后缀 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_css_style'>css&#95;style</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 样式 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_type'>type</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 类型  1文档2图片4音乐3视频5其它 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_bucket_name'>bucket&#95;name</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 文件存储空间名 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_oss_url'>oss&#95;url</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> OSS文件路径 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_file_name'>file&#95;name</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 文件夹名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_lable'>lable</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 标签 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_file_info_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;file&#95;info</td>
		<td> ON id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_job' onclick='window.scrollTo(680, 688);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_job</h5></a>
<p class="text-muted">定时任务表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_job_job_id'>job&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 任务ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_job_job_name'>job&#95;name</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 任务名称 </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_job_job_group'>job&#95;group</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 任务组名 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_method_name'>method&#95;name</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 任务方法 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_method_params'>method&#95;params</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 方法参数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_cron_expression'>cron&#95;expression</a></td>
		<td> varchar&#40; 255 &#41;   DEFAULT '' </td>
		<td> cron执行表达式 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_misfire_policy'>misfire&#95;policy</a></td>
		<td> varchar&#40; 20 &#41;   DEFAULT '3' </td>
		<td> 计划执行错误策略（1立即执行 2执行一次 3放弃执行） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 状态（0正常 1暂停） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注信息 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;job</td>
		<td> ON job&#95;id&#44; job&#95;name&#44; job&#95;group</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_job_log' onclick='window.scrollTo(872, 688);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_job_log</h5></a>
<p class="text-muted">任务日志表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_job_log_job_log_id'>job&#95;log&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 任务日志ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_job_log_job_name'>job&#95;name</a></td>
		<td> varchar&#40; 64 &#41;   </td>
		<td> 任务名称 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_job_log_job_group'>job&#95;group</a></td>
		<td> varchar&#40; 64 &#41;   </td>
		<td> 任务组名 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_method_name'>method&#95;name</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 任务方法 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_method_params'>method&#95;params</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 方法参数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_job_message'>job&#95;message</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 日志信息 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 执行状态（0正常 1失败） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_exception_info'>exception&#95;info</a></td>
		<td> varchar&#40; 2000 &#41;   DEFAULT '' </td>
		<td> 异常信息 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_job_log_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;job&#95;log</td>
		<td> ON job&#95;log&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_logininfor' onclick='window.scrollTo(200, 448);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_logininfor</h5></a>
<p class="text-muted">登录日志表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_logininfor_info_id'>info&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 访问ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_login_name'>login&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 登录账号 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_ipaddr'>ipaddr</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 登录IP地址 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_login_location'>login&#95;location</a></td>
		<td> varchar&#40; 255 &#41;   DEFAULT '' </td>
		<td> 登录地点 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_browser'>browser</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 浏览器类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_os'>os</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 操作系统 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 登录状态（0成功 1失败） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_msg'>msg</a></td>
		<td> varchar&#40; 255 &#41;   DEFAULT '' </td>
		<td> 提示消息 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_logininfor_login_time'>login&#95;time</a></td>
		<td> datetime   </td>
		<td> 访问时间 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;logininfor</td>
		<td> ON info&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_menu' onclick='window.scrollTo(424, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_menu</h5></a>
<p class="text-muted">菜单表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_menu_menu_id'>menu&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 菜单ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_menu_menu_name'>menu&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 菜单名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_parent_id'>parent&#95;id</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 父菜单ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_order_num'>order&#95;num</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 显示顺序 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_url'>url</a></td>
		<td> varchar&#40; 200 &#41;   DEFAULT '#' </td>
		<td> 请求地址 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_menu_type'>menu&#95;type</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '' </td>
		<td> 菜单类型（M目录 C菜单 F按钮） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_visible'>visible</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 菜单状态（0显示 1隐藏） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_perms'>perms</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 权限标识 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_icon'>icon</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '#' </td>
		<td> 菜单图标 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_menu_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;menu</td>
		<td> ON menu&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_mq_exchanges' onclick='window.scrollTo(648, 384);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_mq_exchanges</h5></a>
<p class="text-muted">MQ交换器表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_mq_exchanges_exchanges_id'>exchanges&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 编号 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_name'>name</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 交换机名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_type'>type</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_durability'>durability</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 是否持久化 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_auto_delete'>auto&#95;delete</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 不再被使用时&#40;没有任何绑定的情况下），是否由RabbitMQ自动删除 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_internal'>internal</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 内部的 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_user_who_performed_action'>user&#95;who&#95;performed&#95;action</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 被谁使用 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_arguments'>arguments</a></td>
		<td> varchar&#40; 1000 &#41;   </td>
		<td> 参数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_vhost'>vhost</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 虚拟主机 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_exchanges_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;mq&#95;exchanges</td>
		<td> ON exchanges&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_mq_exchanges_queue' onclick='window.scrollTo(920, 320);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_mq_exchanges_queue</h5></a>
<p class="text-muted">交换器队列关联表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_mq_exchanges_queue_exchanges_id'>exchanges&#95;id</a></td>
		<td> int   </td>
		<td> 交换器ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_mq_exchanges_queue_queue_id'>queue&#95;id</a></td>
		<td> int   </td>
		<td> 队列ID </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;mq&#95;exchanges&#95;queue</td>
		<td> ON exchanges&#95;id&#44; queue&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_mq_message_log' onclick='window.scrollTo(920, 416);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_mq_message_log</h5></a>
<p class="text-muted">MQ消息发送表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_mq_message_log_message_id'>message&#95;id</a></td>
		<td> varchar&#40; 128 &#41;   </td>
		<td> 消息唯一ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_message'>message</a></td>
		<td> varchar&#40; 5000 &#41;   </td>
		<td> 消息内容 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_try_count'>try&#95;count</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 重试次数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_status'>status</a></td>
		<td> varchar&#40; 10 &#41;   DEFAULT '' </td>
		<td> 消息投递状态 0 投递中 1 投递成功 2 投递失败 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_next_retry'>next&#95;retry</a></td>
		<td> timestamp   </td>
		<td> 下一次重试时间 或 超时时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_create_time'>create&#95;time</a></td>
		<td> timestamp   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_message_log_update_time'>update&#95;time</a></td>
		<td> timestamp   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_mq_message_log_exchange'>exchange</a></td>
		<td> varchar&#40; 200 &#41;   </td>
		<td> 交换器 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_mq_message_log_routing_key'>routing&#95;key</a></td>
		<td> varchar&#40; 200 &#41;   </td>
		<td> 路由key </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;mq&#95;message&#95;log</td>
		<td> ON message&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_mq_queue' onclick='window.scrollTo(360, 464);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_mq_queue</h5></a>
<p class="text-muted">MQ队列表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_mq_queue_queue_id'>queue&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 编号 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_mq_queue_queue_name'>queue&#95;name</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 队列名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_durability'>durability</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 是否持久化 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_auto_delete'>auto&#95;delete</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 不再被使用时&#40;没有任何绑定的情况下），是否由RabbitMQ自动删除 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_arguments'>arguments</a></td>
		<td> varchar&#40; 1000 &#41;   </td>
		<td> 参数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_routing_key'>routing&#95;key</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 路由Key </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_app_name'>app&#95;name</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 应用名称&#40;被那个系统使用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_mq_queue_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;mq&#95;queue</td>
		<td> ON queue&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_notice' onclick='window.scrollTo(1000, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_notice</h5></a>
<p class="text-muted">系统公告</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_notice_notice_id'>notice&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 公告ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_notice_notice_title'>notice&#95;title</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 公告标题 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_notice_notice_type'>notice&#95;type</a></td>
		<td> char&#40; 1 &#41;   </td>
		<td> 公告类型（1通知 2公告） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_notice_content'>notice&#95;content</a></td>
		<td> varchar&#40; 2000 &#41;   </td>
		<td> 公告内容 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 公告状态（0正常 1关闭） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_notice_remark'>remark</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;notice</td>
		<td> ON notice&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_oper_log' onclick='window.scrollTo(60, 480);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_oper_log</h5></a>
<p class="text-muted">操作日志表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_oper_log_oper_id'>oper&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 日志主键 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_title'>title</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 模块标题 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_business_type'>business&#95;type</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 业务类型（0其它 1新增 2修改 3删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_method'>method</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 方法名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_operator_type'>operator&#95;type</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 操作类别（0其它 1后台用户 2手机端用户） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_name'>oper&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 操作人员 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_dept_name'>dept&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 部门名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_url'>oper&#95;url</a></td>
		<td> varchar&#40; 255 &#41;   DEFAULT '' </td>
		<td> 请求URL </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_ip'>oper&#95;ip</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 主机地址 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_location'>oper&#95;location</a></td>
		<td> varchar&#40; 1000 &#41;   DEFAULT '' </td>
		<td> 操作地点 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_param'>oper&#95;param</a></td>
		<td> varchar&#40; 2000 &#41;   DEFAULT '' </td>
		<td> 请求参数 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_status'>status</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 操作状态（0正常 1异常） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_error_msg'>error&#95;msg</a></td>
		<td> varchar&#40; 2000 &#41;   DEFAULT '' </td>
		<td> 错误消息 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_oper_log_oper_time'>oper&#95;time</a></td>
		<td> datetime   </td>
		<td> 操作时间 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;oper&#95;log</td>
		<td> ON oper&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_post' onclick='window.scrollTo(280, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_post</h5></a>
<p class="text-muted">岗位表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_post_post_id'>post&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 岗位ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_post_post_code'>post&#95;code</a></td>
		<td> varchar&#40; 64 &#41;   </td>
		<td> 岗位编码 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_post_post_name'>post&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   </td>
		<td> 岗位名称 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_post_post_sort'>post&#95;sort</a></td>
		<td> int   </td>
		<td> 显示顺序 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_post_status'>status</a></td>
		<td> char&#40; 1 &#41;   </td>
		<td> 状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_post_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_post_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_post_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_post_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_post_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;post</td>
		<td> ON post&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_role' onclick='window.scrollTo(152, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_role</h5></a>
<p class="text-muted">角色表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_role_role_id'>role&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 角色ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_role_role_name'>role&#95;name</a></td>
		<td> varchar&#40; 30 &#41;   </td>
		<td> 角色名称 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_role_role_key'>role&#95;key</a></td>
		<td> varchar&#40; 100 &#41;   </td>
		<td> 角色权限字符串 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_role_role_sort'>role&#95;sort</a></td>
		<td> int   </td>
		<td> 显示顺序 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_data_scope'>data&#95;scope</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '1' </td>
		<td> 数据范围（1：全部数据权限 2：自定数据权限） </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_role_status'>status</a></td>
		<td> char&#40; 1 &#41;   </td>
		<td> 角色状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_del_flag'>del&#95;flag</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标志（0代表存在 2代表删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_role_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;role</td>
		<td> ON role&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_role_dept' onclick='window.scrollTo(104, 352);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_role_dept</h5></a>
<p class="text-muted">角色部门关联表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_role_dept_role_id'>role&#95;id</a></td>
		<td> int   </td>
		<td> 角色ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_role_dept_dept_id'>dept&#95;id</a></td>
		<td> int   </td>
		<td> 部门ID </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;role&#95;dept</td>
		<td> ON role&#95;id&#44; dept&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_role_menu' onclick='window.scrollTo(216, 352);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_role_menu</h5></a>
<p class="text-muted">角色菜单关联表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_role_menu_role_id'>role&#95;id</a></td>
		<td> int   </td>
		<td> 角色ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_role_menu_menu_id'>menu&#95;id</a></td>
		<td> int   </td>
		<td> 菜单ID </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;role&#95;menu</td>
		<td> ON role&#95;id&#44; menu&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_sms_config' onclick='window.scrollTo(168, 704);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_sms_config</h5></a>
<p class="text-muted">短息配置</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_sms_config_id'>id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 主键 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_name'>name</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 名称 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_config_sms_key'>sms&#95;key</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 键 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_config_sms_value'>sms&#95;value</a></td>
		<td> varchar&#40; 500 &#41;   </td>
		<td> 值 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_config_del_flag'>del&#95;flag</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标志（0代表存在 2代表删除） </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;sms&#95;config</td>
		<td> ON id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_sms_template' onclick='window.scrollTo(312, 704);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_sms_template</h5></a>
<p class="text-muted">短息模板</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_sms_template_id'>id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td>  </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_name'>name</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 模版名称 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_code'>code</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 模版编码 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_business_type'>business&#95;type</a></td>
		<td> varchar&#40; 4 &#41;   </td>
		<td> 业务类型 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_template_id'>template&#95;id</a></td>
		<td> varchar&#40; 20 &#41;   </td>
		<td> 模版ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_template_content'>template&#95;content</a></td>
		<td> varchar&#40; 2000 &#41;   </td>
		<td> 模版内容 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_template_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 32 &#41;   </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_template_create_date'>create&#95;date</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_template_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 32 &#41;   </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_template_update_date'>update&#95;date</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_sms_template_del_flag'>del&#95;flag</a></td>
		<td> varchar&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标记（0：正常；1：删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_sms_template_remarks'>remarks</a></td>
		<td> varchar&#40; 255 &#41;   </td>
		<td> 备注信息 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;sms&#95;template</td>
		<td> ON id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_ues_en_data' onclick='window.scrollTo(504, 400);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_ues_en_data</h5></a>
<p class="text-muted">UES数据加密表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_ues_en_data_id'>id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 编号 </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#unq'/></svg></td>
		<td><a name='ry.sys_ues_en_data_ticket'>ticket</a></td>
		<td> varchar&#40; 128 &#41;   </td>
		<td> 票据 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_ues_en_data_encrypt_key'>encrypt&#95;key</a></td>
		<td> varchar&#40; 1024 &#41;   </td>
		<td> 加密密码 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_ues_en_data_encrypt_data'>encrypt&#95;data</a></td>
		<td> varchar&#40; 2000 &#41;   </td>
		<td> 加密密文 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_version'>version</a></td>
		<td> varchar&#40; 10 &#41;   </td>
		<td> 版本 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_ues_en_data_encrypt_type'>encrypt&#95;type</a></td>
		<td> varchar&#40; 128 &#41;   </td>
		<td> 加密类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_ues_en_data_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;ues&#95;en&#95;data</td>
		<td> ON id</td>
		<td>  </td>
	</tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#unq'/></svg></td><td>ticket&#95;unique</td>
		<td> ON ticket</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_user' onclick='window.scrollTo(60, 80);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_user</h5></a>
<p class="text-muted">用户表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_user_id'>user&#95;id</a></td>
		<td> int  AUTOINCREMENT  </td>
		<td> 用户ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_parent_user_id'>parent&#95;user&#95;id</a></td>
		<td> int   </td>
		<td> 用户父ID </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_dept_id'>dept&#95;id</a></td>
		<td> int   </td>
		<td> 部门ID </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_user_login_name'>login&#95;name</a></td>
		<td> varchar&#40; 30 &#41;   </td>
		<td> 登录账号 </td>
	</tr>
	<tr>
		<td>*</td>
		<td><a name='ry.sys_user_user_name'>user&#95;name</a></td>
		<td> varchar&#40; 30 &#41;   </td>
		<td> 用户昵称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_user_type'>user&#95;type</a></td>
		<td> varchar&#40; 2 &#41;   DEFAULT '00' </td>
		<td> 用户类型（00系统用户） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_email'>email</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 用户邮箱 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_phonenumber'>phonenumber</a></td>
		<td> varchar&#40; 11 &#41;   DEFAULT '' </td>
		<td> 手机号码 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_sex'>sex</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 用户性别（0男 1女 2未知） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_avatar'>avatar</a></td>
		<td> varchar&#40; 100 &#41;   DEFAULT '' </td>
		<td> 头像路径 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_password'>password</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 密码 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_salt'>salt</a></td>
		<td> varchar&#40; 20 &#41;   DEFAULT '' </td>
		<td> 盐加密 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_status'>status</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 帐号状态（0正常 1停用） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_del_flag'>del&#95;flag</a></td>
		<td> char&#40; 1 &#41;   DEFAULT '0' </td>
		<td> 删除标志（0代表存在 2代表删除） </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_login_ip'>login&#95;ip</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 最后登陆IP </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_login_date'>login&#95;date</a></td>
		<td> datetime   </td>
		<td> 最后登陆时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_create_by'>create&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 创建者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_create_time'>create&#95;time</a></td>
		<td> datetime   </td>
		<td> 创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_update_by'>update&#95;by</a></td>
		<td> varchar&#40; 64 &#41;   DEFAULT '' </td>
		<td> 更新者 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_update_time'>update&#95;time</a></td>
		<td> datetime   </td>
		<td> 更新时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_remark'>remark</a></td>
		<td> varchar&#40; 500 &#41;   DEFAULT '' </td>
		<td> 备注 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;user</td>
		<td> ON user&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_user_online' onclick='window.scrollTo(60, 448);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_user_online</h5></a>
<p class="text-muted">在线用户表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_online_sessionId'>sessionId</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 用户会话id </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_login_name'>login&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 登录账号 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_dept_name'>dept&#95;name</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 部门名称 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_ipaddr'>ipaddr</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 登录IP地址 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_login_location'>login&#95;location</a></td>
		<td> varchar&#40; 255 &#41;   DEFAULT '' </td>
		<td> 登录地点 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_browser'>browser</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 浏览器类型 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_os'>os</a></td>
		<td> varchar&#40; 50 &#41;   DEFAULT '' </td>
		<td> 操作系统 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_status'>status</a></td>
		<td> varchar&#40; 10 &#41;   DEFAULT '' </td>
		<td> 在线状态on&#95;line在线off&#95;line离线 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_start_timestamp'>start&#95;timestamp</a></td>
		<td> datetime   </td>
		<td> session创建时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_last_access_time'>last&#95;access&#95;time</a></td>
		<td> datetime   </td>
		<td> session最后访问时间 </td>
	</tr>
	<tr>
		<td>&nbsp;</td>
		<td><a name='ry.sys_user_online_expire_time'>expire&#95;time</a></td>
		<td> int   DEFAULT 0 </td>
		<td> 超时时间，单位为分钟 </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;user&#95;online</td>
		<td> ON sessionId</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_user_post' onclick='window.scrollTo(60, 352);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_user_post</h5></a>
<p class="text-muted">用户岗位关联表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_post_user_id'>user&#95;id</a></td>
		<td> int   </td>
		<td> 用户ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_post_post_id'>post&#95;id</a></td>
		<td> int   </td>
		<td> 岗位ID </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;user&#95;post</td>
		<td> ON user&#95;id&#44; post&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

<br><br>
<div class='card'><div class='card-body'><a name='ry.sys_user_role' onclick='window.scrollTo(360, 352);return false;' style='cursor:pointer;'><h5 class='card-title'>Table sys_user_role</h5></a>
<p class="text-muted">用户角色表</p>
<table class='table table-sm table-bordered small' style='table-layout: fixed; word-wrap: break-word;'>
<thead>
<tr><th style='width:5%'>Idx</th><th style='width:20%'>Field Name</th><th style='width:23%'>Data Type</th><th style='width:52%'>Description</th></tr>
</thead>
<tbody>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_role_user_id'>user&#95;id</a></td>
		<td> int   </td>
		<td> 用户ID </td>
	</tr>
	<tr>
		<td>*<svg width='14' height='14'><use xlink:href='#pk'/></svg></td>
		<td><a name='ry.sys_user_role_role_id'>role&#95;id</a></td>
		<td> int   </td>
		<td> 角色ID </td>
	</tr>
<tr><th colspan='4'>Indexes</th></tr>
	<tr>		<td><svg width='14' height='14'><use xlink:href='#pk'/></svg></td><td>pk&#95;sys&#95;user&#95;role</td>
		<td> ON user&#95;id&#44; role&#95;id</td>
		<td>  </td>
	</tr>
</tbody>
</table></div></div>

</div>
<br><br></body></html>
